Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг 4.65/54: Рейтинг темы: голосов - 54, средняя оценка - 4.65
Leshiy1
0 / 0 / 0
Регистрация: 03.04.2010
Сообщений: 153
1

В числе 15 поменять местами младший и старший байты

07.04.2010, 16:33. Просмотров 10059. Ответов 24
Метки нет (Все метки)

Здравствуйте всем
объясните пожалуйста как например в числе 15 поменять местами младший и старший байты
(Я Си изучаю только два дня)

Добавлено через 8 минут
Переменная типа int
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.04.2010, 16:33
Ответы с готовыми решениями:

Поменять местами старший и младший полубайты
Как поменять старший и младший полубайт беззнакового короткого целого местами?...

Поменять местами старший и младший полубайт беззнакового короткого целого
ребят, помогите Используя битовые операции, поменять местами старший и младший...

Поменять местами байты
Есть два байта 0x1f и 0xf0 - ну или другие два случайные. Они стоят в...

Поменять местами средние байты заданного числа
Здравствуйте, нужна помощь с данным заданием Заранее благодарю) "Программе...

Поменять местами левый и правый байты целого аргумента
разработайте макрос swab(х) который меняет местами левый и правый байты целого...

24
kirich iz Che
0 / 0 / 1
Регистрация: 29.03.2010
Сообщений: 25
04.07.2010, 21:56 21
Цитата Сообщение от fasked Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
#include <iostream>
 
int main()
{
   unsigned int dword;
   std::cin >>  dword;
 
   dword = (dword << 24) | (dword & 0x00FFFF00) | (dword >> 24);
 
   std::cout << dword;
}
вот теперь вся
о да.. клевые несколько строчек кода)
0
fasked
Эксперт С++
4982 / 2561 / 241
Регистрация: 07.10.2009
Сообщений: 4,311
Записей в блоге: 1
05.07.2010, 00:20 22
Цитата Сообщение от kirich iz Che Посмотреть сообщение
о да.. клевые несколько строчек кода)
а что ты еще хочешь?
0
kirich iz Che
0 / 0 / 1
Регистрация: 29.03.2010
Сообщений: 25
05.07.2010, 06:48 23
Цитата Сообщение от fasked Посмотреть сообщение
а что ты еще хочешь?
все хорошо, просто неожиданно короткл
0
Genius Ignat
1241 / 779 / 108
Регистрация: 16.09.2009
Сообщений: 2,014
10.07.2010, 21:03 24
Еще как вариант.
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
#include <iostream>
using namespace std;
 
//Функция обменивает байты в переданном блоке данных, номера байтов задаются третим и четвертым параметрами.                                                                                  */
long swap_bytes(void *buf, unsigned long size_b, unsigned long num_b1, unsigned num_b2);
int main(){
    int n=1022221113;
    cout<<n<<endl;
    swap_bytes(&n,sizeof(int),0,sizeof(int)-1);   //меняеться последний с первым.
    cout<<n<<endl;
return 0;
}
 
long swap_bytes(void *buf, unsigned long size_b, unsigned long num_b1, unsigned num_b2){
if(size_b<=1)return -1;              
if(num_b1==num_b2)return -2;         
if(num_b1>=size_b||num_b2>=size_b)return -3; 
char *p = ( char*)buf;   
//Обмен байт с номерами.
char tmp = p[num_b1];
p[num_b1] = p[num_b2];
p[num_b2] = tmp;
//----------------------
return 0;
}
0
Hotactioncop
0 / 0 / 0
Регистрация: 02.10.2018
Сообщений: 1
02.10.2018, 16:00 25
Возможно кто-нибудь меня поправит, данный вариант должен подойти к любому числу в пределах типа int (4 байта):
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
#include <stdio.h>
 
int main (void)
{
    int x, y, z, w;
    printf ("Введите любое число от -2 147 483 647 до 2 147 483 646 и я заменю младший и старший его байты:");
    scanf ("%d", &x);
    if (x >= 0)
    {
        /*Вычисляем младший байт числа путем деления числа по модулю %256.
        Затем вычисляем старший байт числа путем вычитания из самого числа (состоит из 4х байтов) - 3 (три) его предыдущий байта. 
        Чтобы вычислить 3 его предыдущих байта, делим число по модулю %16777216 (2 в 24 степени).
        Вычисляем средние его байты (2ой и 3ий) путем вычитания из начального числа - его старшего и младшего байтов.
        Для замены старшего и младшего байтов - совершаем операцию умножения младшего байта на 2 в 24 степени, и деления его старшего байта на 2 в 24 степени.
        Иначе можно произвести сдвиг >> 24 и << 24 соответственно. Но может быть зайдествовано не все 24 сдвига, а только 5, поэтому я умноюа на 2 в степени.
        Произвожу сложение младшего, старшего и средних байтов через побитовую операцию OR. */
        y = x%256;
        z = x - (x%16777216);
        x = (x-y) - z;
        printf ("ДО СМЕНЫ БАЙТОВ:\nСтарший байт равен %d\nМладший байт равен %d\nВторой и третий байт представляют собой %d\n\n", z, y, x);
        y = y * 16777216;
        z = z / 16777216;
        printf ("ПОСЛЕ СМЕНЫ БАЙТОВ:\nСтарший байт равен %d\nМладший байт равен %d\nВторой и третий байт представляют собой %d\n", z, y, x);
        w = y | z;
        x = x | w;
        printf ("Сумма старшего и младшего байтов равна %d\n\n", w);
        printf ("Ваше число теперь имеет вид %d", x);
    }
    else
    {
        /*Поскольку число отрицательное, то произвожу его инверсию. Вычисляю его младший байт делением по модулю %256,
        старший байт делением по модулю % 16777216 и средние байты - вычитанием из инвертированного числа - его младший и старшие байты.
        Переношу младший байт в адрес старшего путем умножения на 2 в 24 степени (иначе говоря сдвиг << 24).
        Переношу старший байт в адрес младшего путем деления на 2 в 24 степени (иначе говоря сдвиг >> 24).
        Произвожу сложение младшего, старшего и средних байтов через побитовую операцию OR.
        И возвращаю число путем инвертирования результата предыдущей операции.*/
        x = ~x;
        printf ("После инварсии:%d\n\n", x);
        y = x%256;
        z = x - (x%16777216);
        x = (x-y) - z;
        printf ("Старший байт равен %d\nМладший байт равен %d\nВторой и третий байт представляют собой %d\n\n", z, y, x);
        y = y * 16777216;
        z = z / 16777216;
        printf ("ПОСЛЕ СМЕНЫ БАЙТОВ:\nСтарший байт равен %d\nМладший байт равен %d\nВторой и третий байт представляют собой %d\n\n", z, y, x);
        w = y | z;
        printf ("Сумма старшего и младшего байтов равна %d\n\n", w);
        x = x | w;
        x = ~x;
        printf ("Ваше число теперь имеет вид %d", x);
    }
    return 0;
}
0
02.10.2018, 16:00
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.10.2018, 16:00

Поменять цифры в числе местами
салам!) помогите решить одну задачу, нужно вывести число цифрами наоборот....

В числе поменять местами цифры
Дано число ABCDEF.GHIKLM(в котором буквы – это любые цифры (0..9)) в этом числе...

N-значное число, вывести младший и старший разряд
Составить программу. Дано n-значное число longint. Произвести с ним действия...


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

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

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