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

Побитовый сдвиг с заполнением нулями - C++

Войти
Регистрация
Восстановить пароль
 
hiphone
13 / 13 / 3
Регистрация: 28.01.2012
Сообщений: 542
28.07.2016, 14:32     Побитовый сдвиг с заполнением нулями #1
Как реализовать побитовый сдвиг с заполнением нулями, есть такой код на JS

Javascript
1
2
3
4
5
for (var b = 0; 256 > b; b++) {
      for (var c = b, d = 0; 8 > d; d++)
            c = c & 1 ? c >>> 1 ^ 3988292384 : c >>> 1;
      m.crc_table[b] = c
}
переношу его в таком виде:

C++
1
2
3
4
5
6
7
8
        long long c;
    int b;
    int  d;
    for (b = 0; 256 > b; b++){
        for (c = b, d = 0; 8 > d; d++)
            c = c & 1 ? c >> 1 ^ 3988292384 : c >> 1;
        crc_table[b] = c;
    }
но в результате вместо:

0
1996959894
-301047508
.....

я получаю

0
1996959894
3993919788
...

Добавлено через 10 часов 45 минут
C++
1
c = c & 1 ? (unsigned long long)c >> 1 ^ 3988292384 : (unsigned long long)c >> 1;
так тоже не получается
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.07.2016, 14:32     Побитовый сдвиг с заполнением нулями
Посмотрите здесь:

Побитовый сдвиг C++
C++ Побитовый сдвиг массива
C++ Побитовый сдвиг
Побитовый сдвиг C++
Реализовать функцию, которая осуществляет циклический побитовый сдвиг вправо на n позиций C++
Не могу понять, как работает побитовый сдвиг C++
Побитовый сдвиг C++
Как происходит побитовый сдвиг? C++
Побитовый сдвиг C++
C++ Побитовый сдвиг влево и вправо
Побитовый сдвиг C++
Как реализовать правильный побитовый сдвиг? C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
HighPredator
 Аватар для HighPredator
5385 / 1768 / 323
Регистрация: 10.12.2010
Сообщений: 5,233
Записей в блоге: 3
30.07.2016, 12:25     Побитовый сдвиг с заполнением нулями #2
У вас проблема в том, что вы взяли плохо подходящий код за основу. Плохо подходящий в том смысле, что в джаве и производных нет понятия беззнаковых целых как типов данных. Вследствие этого вам тяжело воспроизвести механику и сделать логический сдвиг >>> на базе арифметического >>, который в C/C++ ведет себя как логический только на беззнаковых типах данных.

Поэтому, поскольку вы вычисляете вспомогательную таблицу для контрольной суммы, сделайте сразу как надо. Образец здесь: Расчет контрольных сумм у файла - С/Си а вычисление таблицы найдете, циклы узнаете в момент
Yandex
Объявления
30.07.2016, 12:25     Побитовый сдвиг с заполнением нулями
Ответ Создать тему
Опции темы

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