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

Перевернуть шестнадцатеричное число oxА28Е - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 27, средняя оценка - 4.93
олягуся
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 11
30.06.2010, 20:02     Перевернуть шестнадцатеричное число oxА28Е #1
Помогите решить задачу: дано шестнадцатеричное число oxА28Е надо перевернуть его так, чтобы последний бит стал первым и так далее, и вывести его на экран в двоичном виде(используя битовые операции и маски)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.06.2010, 20:02     Перевернуть шестнадцатеричное число oxА28Е
Посмотрите здесь:

C++ Заменить во введенной строке каждую последовательность <xx> (где xx – двухзначное шестнадцатеричное число) на символ с номером xx
Написать программу, которая преобразует введенное с клавиатуры двухразрядное шестнадцатеричное число в десятичное C++
C++ Как преобразовать шестнадцатеричное число в строку?
Написать программу которая преобразует введенное с клавиатуры трехразрядное шестнадцатеричное число в десятичное C++
C++ Перевести в двоичную систему счисления произвольное шестнадцатеричное число
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
odip
Эксперт C++
 Аватар для odip
7225 / 3287 / 58
Регистрация: 17.06.2009
Сообщений: 14,165
01.07.2010, 11:17     Перевернуть шестнадцатеричное число oxА28Е #2
Ну самое простое и наглядное - разложить в массив целых чисел
Где в элемент массива записать ровно один бит
И потом собрать из массива в число, но в обратном порядке
олягуся
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 11
01.07.2010, 18:45  [ТС]     Перевернуть шестнадцатеричное число oxА28Е #3
если не трудно как это сделать?
Prividenie
74 / 74 / 6
Регистрация: 05.10.2008
Сообщений: 233
01.07.2010, 19:21     Перевернуть шестнадцатеричное число oxА28Е #4
так не пройдет?
C
1
2
3
4
5
6
7
//Перевернуть 2 байт
i =(i << 8) | (i >> 8);
i &= 0xFFFF;
 
//Перевернуть 4 байт (int)
i = (i << 24) | (i << 8);
i &= 0xFFFF0000;
Добавлено через 15 минут
а так вывести:
Двоичный код числа
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9373 / 5423 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
01.07.2010, 19:27     Перевернуть шестнадцатеричное число oxА28Е #5
олягуся, точно биты нужно переворачивать, а не шестнадцатиричные цифры? Если да, то вот
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#include <stdio.h>
#include <stdlib.h>
#include <limits.h>
 
void binprn(unsigned int num){
    if ( num / 2 )
        binprn(num / 2);
    printf("%d", num % 2);
}
 
 
int main(void){
    unsigned int num, res;
    int i;
 
    while ( 1 ) {
        printf("Number: ");
        if ( scanf("%u", &num) != 1 ){
            perror("scanf");
            exit(EXIT_FAILURE);
        }
        if ( ! num )
            break;
        res = 0;
        for ( i = 0; i < CHAR_BIT * sizeof(int); ++i )
            if ( num & 1 << i )
                res += 1 << ( CHAR_BIT * sizeof(int) - 1 - i);
        printf("Hex:\nnum = %#x\nres = %#x\n", num, res);
        printf("Bin:\nnum = ");
        binprn(num);
        printf("\nres = ");
        binprn(res);
        printf("\n");
    }
 
    exit(EXIT_SUCCESS);
}
fasked
Эксперт C++
 Аватар для fasked
4925 / 2505 / 180
Регистрация: 07.10.2009
Сообщений: 4,306
Записей в блоге: 1
01.07.2010, 19:34     Перевернуть шестнадцатеричное число oxА28Е #6
easybudda,
C
1
2
3
4
5
6
7
8
WORD32 wbrev(WORD32 X)
{
    X = (X & 0x55555555) << 1 | (X >> 1) & 0x55555555;
    X = (X & 0x33333333) << 2 | (X >> 2) & 0x33333333;
    X = ((X >> 4) & 0x0F0F0F0F) | ((X & 0x0F0F0F0F) << 4);
    X = (X << 24) | ((X & 0xFF00) << 8) | ((X >> 8) & 0xFF00) | (X >> 24);
    return X;   
}
кстати, результат будет сильно зависеть от необходимой разрядности. так что надо бы с этим моментом определиться. эта функция для 32-х битных.
олягуся
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 11
01.07.2010, 20:26  [ТС]     Перевернуть шестнадцатеричное число oxА28Е #7
а как начало и конец? я только учусь

Добавлено через 8 минут
Нужно перевернуть так чтобы крайний бит стал первым, и так далее
fasked
Эксперт C++
 Аватар для fasked
4925 / 2505 / 180
Регистрация: 07.10.2009
Сообщений: 4,306
Записей в блоге: 1
01.07.2010, 20:40     Перевернуть шестнадцатеричное число oxА28Е #8
олягуся, понимаешь, числа оно конечно и в африке число, но мне надо знать какое максимальное число бит в числе.
то есть максимальное число может быть 0xFFFF или 0xFFFFFFFF и т.д.
допустим число 0xA28E в двоичном представлении имеет вид:
Код
1010 0010 1000 1110                     (для 16 битного числа)
0000 0000 0000 0000 1010 0010 1000 1110 (для 32-х битного числа)
сейчас количество бит роли не играет, но если произвести реверс битов, то получаются следующие результаты:
Код
0111 0001 0100 0101                      = 0x7145     = 28997
0111 0001 0100 0101 0000 0000 0000 0000   = 0x71450000 = 1900347392
а если перевести эти числа обратно в HEX-форму, то второе число оказывается намного больше первого, на 4 разряда, если быть точным
олягуся
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 11
01.07.2010, 21:04  [ТС]     Перевернуть шестнадцатеричное число oxА28Е #9
а как начало и конец? я только учусь


Нужно перевернуть так чтобы крайний бит стал первым, и так далее

Добавлено через 7 минут
мне нужно решение для 16-ти битного числа и как потом его вывести в двоичном виде? только пожалуйста, если можно программу от начало до конца (это мое первое задание) , заранее большое спасибо!

Добавлено через 2 минуты
мне нужно для 16-ти битного

Добавлено через 12 минут
fasked, мне нужно решение для 16-ти битного числа и как потом его вывести в двоичном виде? только пожалуйста, если можно программу от начало до конца (это мое первое задание) , заранее большое спасибо!
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9373 / 5423 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
01.07.2010, 21:44     Перевернуть шестнадцатеричное число oxА28Е #10
fasked, ну да, тут на форуме такие шаманства, помню, были уже... Только мне логику их осмысливать лениво, а запомнить, что там с чем и как менять надо тоже сложно... Но в принципе красиво
Prividenie
01.07.2010, 22:09
  #11

Не по теме:

Цитата Сообщение от easybudda Посмотреть сообщение
Но в принципе красиво
супер!

fasked
Эксперт C++
 Аватар для fasked
4925 / 2505 / 180
Регистрация: 07.10.2009
Сообщений: 4,306
Записей в блоге: 1
02.07.2010, 00:01     Перевернуть шестнадцатеричное число oxА28Е #12
вот задача целиком:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#include <stdio.h>
#include <stdlib.h>
 
/* программа производит битовый реверс 16-битного числа и печатает его в двоичном виде */
 
typedef unsigned short WORD16;
 
void printwb(WORD16);
WORD16 wbrev(WORD16);
 
int main()
{
   printwb(0xA28E);        /* печать исходного числа        */
   printwb(wbrev(0xA28E)); /* печать реверсированного числа */
 
   system("pause");
}
 
/* Комментарии к алгоритму перестановки на примере числа 0xA28E   //
// 1010 0010 1000 1110 - исходное число                           //
// 0101 0001 0100 1101 - ...                                      //
// 0101 0100 0001 0111 - битовый реверс каждого байта в слове     //
// 0100 0101 0111 0001 - перестановка байт в полусловах           //
// 0111 0001 0100 0101 - перестановка полуслов                    */
WORD16 wbrev(WORD16 X)
{
   X = (X & 0x5555) << 1 | (X >> 1) & 0x5555;
   X = (X & 0x3333) << 2 | (X >> 2) & 0x3333;
   X = ((X >> 4) & 0x0F0F) | ((X & 0x0F0F) << 4);
   X = (X << 8) | (X >> 8);
   return X;       
}
// Печать числа в двоичном виде
void printwb(WORD16 X)
{
   for (int n = (sizeof(WORD16)*8 - 1); n >= 0; n--)
   {
      printf("%x",((X >> n) & 1));
 
      if(n%4 == 0)
         printf(" ");
   }
   printf("\n");
}
Добавлено через 5 минут
Цитата Сообщение от easybudda Посмотреть сообщение
Только мне логику их осмысливать лениво, а запомнить, что там с чем и как менять надо тоже сложно...
да тут несложно (раньше я тоже пугался, но после лекций о ассемблеровском программировании (для цифровые сигнальных процессоров TMS) вообще мелочи О_о).
задачка типичная, алгоритм перестановки древний как мир (в комментариях указал, что делает каждая строка в функции), а там можно и налету такие функции шпарить.
олягуся
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 11
06.07.2010, 20:01  [ТС]     Перевернуть шестнадцатеричное число oxА28Е #13
А если отдель но взять число 0x7145 и вывести его в двоичном виде, это как будет?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.07.2010, 12:43     Перевернуть шестнадцатеричное число oxА28Е
Еще ссылки по теме:

C++ Перевернуть число (перевернутое число выводится на экран)
C++ Проверить, образуют ли символы шестнадцатеричное число
C++ Как записать шестнадцатеричное число в переменную типа string?

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

Или воспользуйтесь поиском по форуму:
odip
Эксперт C++
 Аватар для odip
7225 / 3287 / 58
Регистрация: 17.06.2009
Сообщений: 14,165
07.07.2010, 12:43     Перевернуть шестнадцатеричное число oxА28Е #14
0111 0001 0100 0101
Yandex
Объявления
07.07.2010, 12:43     Перевернуть шестнадцатеричное число oxА28Е
Ответ Создать тему
Опции темы

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