14 / 14 / 1
Регистрация: 05.07.2010
Сообщений: 88
1

Циклический сдвиг вправо

12.12.2010, 19:55. Показов 5481. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно сделать цеклический сдвиг машинного слова на 1 байт влево, через union и через побитовые операции.
Вот так я пишу побитовый сдвиг
C++
1
2
    unsigned D=15;
    cout<<(D<<8|D>>24)<<endl;;
а вот с таким union делаю побитовый сдвиг вот так
C++
1
2
3
4
5
6
7
8
9
10
11
union Word
{
      unsigned int _k;
      struct Word4
      {
            unsigned _byte1: 8;
            unsigned _byte2: 8;
            unsigned _byte3: 8;
            unsigned _byte4: 8;
      } _word;
};
C++
1
2
3
4
5
6
7
8
    unsigned t(0);
    Word b;
    b._k=15;
    t=b._word._byte1;
    b._word._byte1=b._word._byte2;
    b._word._byte2=b._word._byte3;
    b._word._byte3=b._word._byte4;
    b._word._byte4=t;
но выдает совершенно разные значения.
Кажется мне, что я совершенно неправ, просто плохо разбираюсь в этой теме. Где ошибся?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.12.2010, 19:55
Ответы с готовыми решениями:

Циклический сдвиг массива вправо
дан двумерный массив MxN нужно осуществить поэлементный сдвиг вправо на 1 элемент

Циклический сдвиг массива влево и вправо
Нужно реализовать циклический сдвиг массива влево и вправо! Например есть массив int- {121605}?...

Циклический сдвиг букв в слове вправо
Перестановка букв в слове (циклический сдвиг вправо)

Одномерный массив. Циклический сдвиг вправо
Дан массив A размера N и целое число K (1 ≤ K ≤ 4, K &lt; N). Осущест- вить циклический сдвиг...

3
0 / 0 / 0
Регистрация: 23.09.2010
Сообщений: 18
12.12.2010, 20:40 2
C
1
2
3
typedef unsigned int Integer;
Integer a, b, c;
c= (a << b ) | (a >> (sizeof(Integer)*8-b));
вот правильный циклический сдвиг.
0
14 / 14 / 1
Регистрация: 05.07.2010
Сообщений: 88
12.12.2010, 21:14  [ТС] 3
может быть он и правельный в общем случае, но в моем результат такой же самый

получается тогда ошибка в сдвиге через union? где там ошибка?
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
13.12.2010, 05:44 4
битовые поля могут по-разному храниться на разных системах
между полями могут быть пустоты
unsigned int может быть равен unsigned short

если хочешь делать через union, делай с массивом char[]
char может иметь или не иметь знака и подвержен переполнению, в случае когда имеет
поэтому, если может быть переполнение, используй unsigned char[]
0
13.12.2010, 05:44
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.12.2010, 05:44
Помогаю со студенческими работами здесь

Рекурсия: циклический сдвиг массива вправо
дана такая задача (Напишите рекурсивную функцию, которая принимает двухмерный массив целых чисел...

Циклический сдвиг динамического массива вправо
Подскажите, как выполнить циклический сдвиг в строке динамического массива на некоторое количество...

Циклический сдвиг прямоугольной матрицы на n элементов вправо
Подскажите пожалуйста в чем ошибка. Надо осуществить циклический сдвиг прямоугольной матрицы на n...

Выполнить циклический сдвиг массива на x позиций вправо
Дано натуральное число n, действительные числа A1,.,An. Выполнить циклический сдвиг массива на x...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru