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

изменения порядка битов в 2-ч байтовом целом - C++

Восстановить пароль Регистрация
 
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
07.03.2013, 18:40     изменения порядка битов в 2-ч байтовом целом #1
Доброго времени суток! Решаю следующую задачу, нужно ввести число, а затем поменять порядок битов в нем на обратный, так вот что-то не получается... заранее благодарю за помощь!)

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
45
46
47
48
49
50
51
52
53
54
55
#include "stdafx.h"
#include <iostream>
#include <iomanip>
using namespace std;
 
void displayBits(unsigned);
unsigned reverseBits(unsigned);
 
int main()
{
    unsigned number;
 
    cout << "Enter the number: ";
        cin >> number;
 
    displayBits(number);
    number = reverseBits(number);
    displayBits(number);
 
 
    cout << "\n\n";
    return 0;
}
 
unsigned reverseBits(unsigned input)
{
   unsigned output = 0, displayMask = 1 << 15;
   const int count = 16;
  
   displayBits(output);
   cout << endl;
 
   for(int i = 0; i < count; ++i)
      output |= (input >> i) << (count - 1 - i);
 
   return output;
}  
 
void displayBits(unsigned value)
{
    unsigned c, displayMask = 1 << 15;
 
    cout << setw(7) << "value = ";
 
    for(c = 1; c <= 16; c++)
    {
        cout << (value & displayMask ? '1' : '0');
            value <<= 1;
 
        if(c % 8 == 0)
            cout << " ";
    }
 
    cout << "\n";
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
wtf?
19 / 19 / 0
Регистрация: 03.10.2010
Сообщений: 48
07.03.2013, 19:40     изменения порядка битов в 2-ч байтовом целом #2
Если я правильно понял тогда попробуй так:
C++
1
number = ~number;
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
07.03.2013, 19:47  [ТС]     изменения порядка битов в 2-ч байтовом целом #3
wtf?, скорее всего нет, у вас получиться что все 1 заменяться на нули, а нули на единицы, это другое, мне же нужно было чтобы 00000000 00001111, превратилось в 11110000 00000000, а у ваш способ даст 11111111 11110000 - это не то, но я сделал, вот как получилось:

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
45
46
47
48
49
50
51
52
53
54
55
#include "stdafx.h"
#include <iostream>
#include <iomanip>
using namespace std;
 
void displayBits(unsigned);
unsigned reverseBits(unsigned);
 
int main()
{
    unsigned number;
 
    cout << "Enter the number: ";
        cin >> number;
 
    displayBits(number);
    number = reverseBits(number);
    displayBits(number);
 
 
    cout << "\n\n";
    return 0;
}
 
unsigned reverseBits(unsigned input)
{
   unsigned output = 0, displayMask = 1 << 15;
   const int count = 16;
  
   displayBits(output);
   cout << endl;
 
   for(int i = 0; i < count; ++i)
        output |= ((input >> i) & 1) << (count - 1 - i);
 
   return output;
}  
 
void displayBits(unsigned value)
{
    unsigned c, displayMask = 1 << 15;
 
    cout << setw(7) << "value = ";
 
    for(c = 1; c <= 16; c++)
    {
        cout << (value & displayMask ? '1' : '0');
            value <<= 1;
 
        if(c % 8 == 0)
            cout << " ";
    }
 
    cout << "\n";
}
Kuzia domovenok
 Аватар для Kuzia domovenok
1883 / 1738 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
07.03.2013, 19:48     изменения порядка битов в 2-ч байтовом целом #4
Цитата Сообщение от wtf? Посмотреть сообщение
Если я правильно понял тогда попробуй так:
number = ~number;
К сожалению нет. это инверсия битов
число 0000 0000 0000 0001
будет 1111 1111 1111 1110
а надо 1000 0000 0000 0000
HighPredator
 Аватар для HighPredator
5352 / 1735 / 320
Регистрация: 10.12.2010
Сообщений: 5,120
Записей в блоге: 3
07.03.2013, 20:50     изменения порядка битов в 2-ч байтовом целом #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
38
39
40
#include <iostream>
#include <string>
 
using namespace std;
 
template <class T> void ToBin(const T& N)
{
    T temp=N;
    string s;
    for(unsigned int i=1;i<=8*sizeof(T);i++)
    {
        if(temp&1) s=string("1")+s;
        else s=string("0")+s;
        temp=temp>>1;
    }
    cout<<s<<endl;
}
 
template <class T> void ReverseBitOrder(T& N)
{
    T temp=0;
    T mask=0;
    for(unsigned int i=1;i<=8*sizeof(T);i++)
    {
        mask=(N&1)<<(8*sizeof(T)-i);
        temp=temp^mask;
        N=N>>1;
    }
    N=temp;
}
 
int main()
{
    short r=17;
    ToBin<short>(r);
    ReverseBitOrder<short>(r);
    ToBin<short>(r);
    getchar();
    return 0;
}
palva
 Аватар для palva
2373 / 1595 / 190
Регистрация: 08.06.2007
Сообщений: 6,364
Записей в блоге: 4
07.03.2013, 21:14     изменения порядка битов в 2-ч байтовом целом #6
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <stdio.h>
int main ()
{
    unsigned short int n=0x579B;
    unsigned short int temp=0;
    for(int i=0; i<16; i++) {
        temp <<= 1;
        if(n&1) temp++;
        n >>= 1;
    }
    n = temp;
    printf("%04X\n", n);
    return 0;
}
Jupiter
Каратель
Эксперт C++
6543 / 3963 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
07.03.2013, 21:55     изменения порядка битов в 2-ч байтовом целом #7
C++
1
2
3
4
5
6
7
   uint16_t val = 0xffff - 1, res = 0;
 
   for (uint16_t i = 0; i < 16; ++i)
   {
      if (val & (1 << (15 - i)))
         res |= 1 << i;
   }
Kastaneda
Модератор
Эксперт С++
 Аватар для Kastaneda
4237 / 2770 / 218
Регистрация: 12.12.2009
Сообщений: 7,104
Записей в блоге: 1
Завершенные тесты: 1
07.03.2013, 22:02     изменения порядка битов в 2-ч байтовом целом #8
Недавно было, вот оно же на ассемблере.
vua72
07.03.2013, 22:20
  #9

Не по теме:

Цитата Сообщение от Kastaneda Посмотреть сообщение
Недавно было, вот оно же на ассемблере.
одна команда
Assembler
1
bswap eax

MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.03.2013, 22:22     изменения порядка битов в 2-ч байтовом целом
Еще ссылки по теме:

C++ Написать программу изменения порядка следования элементов динамического массива в обратном порядке
C++ Найти наибольшую цифру в заданном целом числе N
Удалить из одномерного массива все четные элементы без изменения порядка C++

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

Или воспользуйтесь поиском по форуму:
palva
 Аватар для palva
2373 / 1595 / 190
Регистрация: 08.06.2007
Сообщений: 6,364
Записей в блоге: 4
07.03.2013, 22:22     изменения порядка битов в 2-ч байтовом целом #10
vua72, это перестановка байтов, а не битов.
Yandex
Объявления
07.03.2013, 22:22     изменения порядка битов в 2-ч байтовом целом
Ответ Создать тему
Опции темы

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