С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
2 / 2 / 1
Регистрация: 23.10.2012
Сообщений: 66

В чем может быть ошибка? (пример с побитовым сдвигом)

16.11.2012, 16:25. Показов 845. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго дня)

В одной из книжек по С++ (Horton) наткнулся на такую вот небольшую задачку:

C++
1
2
3
unsigned s = 555;
int i = (s >> 4) & ~(~0 << 3);
cout << i;
Дескать, не компилируя, посчитайте, какое число выведет программа?
Я посчитал:
1. ~(~0 << 3) будет 7 (инвертируем ноль, сдвигаем на 3 единицы влево, (типа умножаем на 8), опять инвертируем значение операнда - в результате имеем бинарные 111 или десятичную 7).
2. 255 (бинарная 11111111) при сдвиге вправо дает 15 (или 1111).
3. 15 & 7 = 7

Т.е. на выходе получаем 7. Скомпилировал - программа выводит 2. What the fuck? Ничего не понимаю, в чем ошибся?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.11.2012, 16:25
Ответы с готовыми решениями:

В чем может быть ошибка?
Вот программа: #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;stdio.h&gt; #include &lt;math.h&gt; #include &lt;stdlib.h&gt; #include...

В чем может быть ошибка, и как её вылечить?
Проблема такая. Покуда я студент, то пичкают нас всяческой дрянью, и вот настал язык Си. С С++ я знаком, и ноутбук с никсами прекрасно...

В чем может быть ошибка? (передача аргументов функции)
Есть двумерный массив, симулирующий игровое поле (0 означают пустоту, 8 игрок) Есть некая функция, которую я хочу использовать просто для...

8
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
16.11.2012, 16:31
Цитата Сообщение от Excogit8er Посмотреть сообщение
~(~0 << 3) будет 7
Нет.
sizeof (int)=1: ~=255, 255<<3=248,
sizeof (int)=2: ~=65535, 65535<<3=65528,
0
 Аватар для I.M.
576 / 559 / 47
Регистрация: 16.12.2011
Сообщений: 1,389
16.11.2012, 16:31
Цитата Сообщение от Excogit8er Посмотреть сообщение
255 (бинарная 11111111) при сдвиге вправо дает 15 (или 1111).
откуда 255? там 555
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
16.11.2012, 16:32
sizeof (int)=4: ~=4294967295, 4294967295<<3=4294967288.
0
 Аватар для I.M.
576 / 559 / 47
Регистрация: 16.12.2011
Сообщений: 1,389
16.11.2012, 16:33
taras atavin, еще перед скобкой ~
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
16.11.2012, 16:34
А 7 при сдвиге влево не получается в принципе не из чего, так как справа должны быть ноли, то есть число может быть только кратно степени двойки.
0
2 / 2 / 1
Регистрация: 23.10.2012
Сообщений: 66
16.11.2012, 16:36  [ТС]
Цитата Сообщение от taras atavin Посмотреть сообщение
Нет.
sizeof (int)=1: ~=255, 255<<3=248,
sizeof (int)=2: ~=65535, 65535<<3=65528,
Все равно не пойму )) Почему? Попробовал скомпилировать такое выражение:
cout << ~(~0 << 3);
Выдает 7, все правильно.
0
 Аватар для I.M.
576 / 559 / 47
Регистрация: 16.12.2011
Сообщений: 1,389
16.11.2012, 16:39
Цитата Сообщение от Excogit8er Посмотреть сообщение
~(~0 << 3) будет 7
taras atavin, тут правда 7.
1. 0
2. ~0 - 111..111
3. ~0 << 3 - 11...11000
4. ~(~0 << 3) - 00...00111
5. 00...00111 - 7

Добавлено через 1 минуту
Excogit8er, про вашу ошибку я уже выше написал. Вы числа перпутали
0
2 / 2 / 1
Регистрация: 23.10.2012
Сообщений: 66
16.11.2012, 16:42  [ТС]
Цитата Сообщение от taras atavin Посмотреть сообщение
А 7 при сдвиге влево не получается в принципе не из чего, так как справа должны быть ноли, то есть число может быть только кратно степени двойки.
Имеем 0. То есть в бинарном виде:
0000 0000 0000 0000 0000 0000 0000 0000

Инвертируем (~):
1111 1111 1111 1111 1111 1111 1111 1111

Сдвигаем на 3 значения влево:
1111 1111 1111 1111 1111 1111 1111 1000

Опять инвертируем:
0000 0000 0000 0000 0000 0000 0000 0111

111 = 7



Что не так?

Добавлено через 2 минуты
Цитата Сообщение от I.M. Посмотреть сообщение
откуда 255? там 555
Блин. Точно. Спасибо. От жеж я балбесина...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.11.2012, 16:42
Помогаю со студенческими работами здесь

В чем может быть ошибка? Проблема с выводом очереди
Здравствуйте, нужно создать класс очереди и класс элементов. Вроде всё нормально, но когда запускаю функцию q.Print() программа...

Программа не работает на русском языке. В чем может быть ошибка?
#include&lt;iostream&gt; #include &lt;string&gt; using namespace std; int main() { setlocale (LC_ALL, &quot;rus&quot;); for (int countinue = 0;...

Программа не работает, но ошибок не выдает. В чем может быть ошибка?
#include &lt;iostream&gt; #include &lt;math.h&gt; #include &lt;cstdlib&gt; #define m 8 using namespace std; int main() { int...

В чем может быть ошибка. Расстояние между вершинами дерева
Входные данные: Первая строка содержит количество вершин в дереве n(1&lt;=n&lt;=500000). Вершины имеют значения от 0 до n-1. В следующих n-1...

Неверный результат функции поиска младших битов побитовым сдвигом
Может здесь дело в неявном приведении типов? Добавлено через 23 минуты Есть ф-ция, имеющая два параметра num(число) и...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru