Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 27, средняя оценка - 4.93
олягуся
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 11
#1

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

30.06.2010, 20:02. Просмотров 3515. Ответов 13
Метки нет (Все метки)

Помогите решить задачу: дано шестнадцатеричное число oxА28Е надо перевернуть его так, чтобы последний бит стал первым и так далее, и вывести его на экран в двоичном виде(используя битовые операции и маски)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.06.2010, 20:02
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Перевернуть шестнадцатеричное число oxА28Е (C++):

Как перевести шестнадцатеричное число в char? - C++
Как перевести шестнадцатеричное число в char?

Проверить, образуют ли символы шестнадцатеричное число - C++
Здравствуйте. В Википедии я нашел как "вручную" преобразовать 10-ричное число в шестнадцатеричное и наоборот. А вот как проверить что...

Записать шестнадцатеричное число в десятичной форме - C++
Пусть N такое число, что 0xff = 0xc0 + N. Напишите представление числа N в десятичной системе счисления? Добавлено через 2 минуты N...

Как преобразовать шестнадцатеричное число в строку? - C++
как записать в строку шестнадцатеричное число? например 111111111 в основании 16 в строке должно выглядеть как 4581298449 в основании 10

Как записать шестнадцатеричное число в переменную типа string? - C++
Есть ф-ция, которая переводит целочисленный переменные или просто цифры в шестнадцатеричный вид. Например этот кусок кода выведет в консоль...

Перевести в двоичную систему счисления произвольное шестнадцатеричное число - C++
Добрый день, форумчане. Перевести в двоичную систему счисления произвольное шестнадцатеричное число c++ Препод строго-настрого...

13
odip
Эксперт С++
7159 / 3221 / 59
Регистрация: 17.06.2009
Сообщений: 14,164
01.07.2010, 11:17 #2
Ну самое простое и наглядное - разложить в массив целых чисел
Где в элемент массива записать ровно один бит
И потом собрать из массива в число, но в обратном порядке
1
олягуся
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 11
01.07.2010, 18:45  [ТС] #3
если не трудно как это сделать?
0
Prividenie
74 / 74 / 6
Регистрация: 05.10.2008
Сообщений: 233
01.07.2010, 19:21 #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 минут
а так вывести:
Двоичный код числа
1
easybudda
Модератор
Эксперт CЭксперт С++
9693 / 5643 / 962
Регистрация: 25.07.2009
Сообщений: 10,847
01.07.2010, 19:27 #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);
}
1
fasked
Эксперт С++
4948 / 2528 / 180
Регистрация: 07.10.2009
Сообщений: 4,311
Записей в блоге: 1
01.07.2010, 19:34 #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-х битных.
2
олягуся
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 11
01.07.2010, 20:26  [ТС] #7
а как начало и конец? я только учусь

Добавлено через 8 минут
Нужно перевернуть так чтобы крайний бит стал первым, и так далее
0
fasked
Эксперт С++
4948 / 2528 / 180
Регистрация: 07.10.2009
Сообщений: 4,311
Записей в блоге: 1
01.07.2010, 20:40 #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 / 0
Регистрация: 30.06.2010
Сообщений: 11
01.07.2010, 21:04  [ТС] #9
а как начало и конец? я только учусь


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

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

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

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

Не по теме:

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

0
fasked
Эксперт С++
4948 / 2528 / 180
Регистрация: 07.10.2009
Сообщений: 4,311
Записей в блоге: 1
02.07.2010, 00:01 #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 / 0
Регистрация: 30.06.2010
Сообщений: 11
06.07.2010, 20:01  [ТС] #13
А если отдель но взять число 0x7145 и вывести его в двоичном виде, это как будет?
0
odip
Эксперт С++
7159 / 3221 / 59
Регистрация: 17.06.2009
Сообщений: 14,164
07.07.2010, 12:43 #14
0111 0001 0100 0101
0
07.07.2010, 12:43
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.07.2010, 12:43
Привет! Вот еще темы с ответами:

Пользователь вводит с клавиатуры число, необходимо перевернуть его (число) и вывести на экран. - C++
Сегодняшнее домашнее задание основано именно на этом принципе, однако, вам придется использовать еще и циклы. 1. Пользователь вводит с...

Пользователь вводит с клавиатуры число, необходимо перевернуть его (число) и вывести на экран - C++
2. Пользователь вводит с клавиатуры число, необходимо перевернуть его (число) и вывести на экран.

Перевернуть число (перевернутое число выводится на экран) - C++
Помогите написать программу с комментариями (Рекурсия) Перевернуть число (перевернутое число выводится на экран)

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


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

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

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