Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
newStudent
0 / 0 / 0
Регистрация: 30.10.2010
Сообщений: 13
#1

Битовые операции - C++

14.03.2011, 01:11. Просмотров 787. Ответов 2
Метки нет (Все метки)

Имеется число
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
int x = 85;
// 1010101 - двоичное представление
// 6543210 - номера битов
// нужно взять
// 0,2,3,4 биты и сложить и по модулю 2 ---> 1 ^ 1 ^ 0 ^ 1 = 1
...
// затем сдвинуть x вправо на 1 бит
// 0101010
x >>= 1;
// и в 6-ой бит записать результат сложения по модулю 2 0-го, 2-го, 3-го, 4-го битов, тобишь 1
// x должен стать равным 106
// 1101010
...
как это можно реализовать?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.03.2011, 01:11     Битовые операции
Посмотрите здесь:

Битовые операции - C++
Доброго времени суток! Есть задача: Даны два целых без знаковых числа. Остатки от деления их на 16 заносятся соответственно в 4 младших и...

Битовые операции - C++
Собсно,если используется 4 байтовая переменная,то почему она представлена 16 битами(1010 0110 0010 0110),а не 32 битами?

Битовые операции - C++
Народ дайте ссылку пожалуйста на задачи по сишке где нужно использовать битовые операции! Желательно с решениями!

Битовые операции - C++
Есть код signed int a = 10; a = !a; cout << a; Выводит 0, объясните, почему??

Битовые операции - C++
Здраствуйте, помогите, пожалуйста! Надо написать три функции, используя только битовые (для первых двух) и только битовые и...

Битовые операции - C++
#include<iostream> #include<climits> int main() { unsigned int a = UINT_MAX; unsigned short b = USHRT_MAX; std::cout <<...

Битовые операции - C++
Всем привет! Помогите решить интересную задачу! Нужно ниже указный код переписать без условных операторов используя только битовые операции...

Битовые операции - C++
Приветствую! Изучаю C++, не могу освоить битовые операции (перемещение, исключающие или, инвертирование всякое). Просто не понимаю...

Битовые операции - C++
Не могу разобраться с 4 заданием Реализовал пятое но не в одну строчку и без понятия как сделать в одну П.5.18.Правил Запрещено...

Битовые операции - C++
С помощью битовых операций выести на экран значение к-ого спарва бита. Помогите пожалуйста!что-то в этих битовых операциях не...

Битовые операции - C++
Здравствуйте! нужно решить задачу: в целом числе заменить младший бит старшего байта на 1 решается ли это битовыми сдвигами? и...

Битовые операции - C++
Задача. Я не понимаю что тут делать. Кто то что то понимает? Элементарное я понимаю сдвиги и прочее но это вообще:wall: Умоляю,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Reiji Cross
26 / 26 / 1
Регистрация: 14.05.2010
Сообщений: 57
14.03.2011, 01:45     Битовые операции #2
Выделяй массив под битовое представление и работай с ним, помнится по теории кодирования что-то подобное но посложнее делал, так получилось только так.
accept
4821 / 3241 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
14.03.2011, 11:32     Битовые операции #3
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
>>> x = 85
>>> bin(x)
'0b1010101'
>>> (x & 1), (x >> 2 & 1), (x >> 3 & 1), (x >> 4 & 1)
(1, 1, 0, 1)
>>> n = (x & 1) ^ (x >> 2 & 1) ^ (x >> 3 & 1) ^ (x >> 4 & 1)
>>> x >>= 1
>>> x
42
>>> bin(x)
'0b101010'
>>> n << 6
64
>>> bin(n << 6)
'0b1000000'
>>> x |= n << 6
>>> x
106
>>> bin(x)
'0b1101010'
>>>
C++
1
int x = 85;
если число может быть отрицательное, нужен unsigned int
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru