Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
2 / 2 / 0
Регистрация: 10.03.2020
Сообщений: 3

Перевод из одной системы счисления в другое системы счисления

10.03.2020, 14:50. Показов 1613. Ответов 1

Студворк — интернет-сервис помощи студентам
Здравствуйте, Господа!

Бывает такая необходимость, когда нужно перевести какое-то число в другое представление, вот я решил написать свое решение на языке программировании С, которое я старательно писал для большего понимания и простоты использования данных функций.

bin_to_dec - перевод из 2-ной СС в 10-ное СС.
hex_to_dec - перевод из 16-ной СС в 10-ное СС.
dec_to_bin - перевод из 10-ной в 2-ное СС.
dec_to_hex - перевод из 10-ной в 16-ное СС.


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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
#include <stdio.h>
 
// Перевод двойничной СС в десятичное СС
unsigned long long bin_to_dec(const char *in_bin){
    char *aPtr;
    unsigned int l,c;
    unsigned long long r,x;
 
    r = 0;
    c = 2;
    aPtr = in_bin;
    if(aPtr == NULL) return 0;
    l = strlen(aPtr);
    if(l > 0 && l <= 64){
        l -= 1;
        while(*aPtr){
            x = c;
            if(l > 1){
                for(int j=l-1; j>0; j--)
                    x *= 2;
            } else c--;
            r += (*aPtr-0x30) * x;
            aPtr++;
            l--;
        }
    }
    return r;
}
 
// Перевод шестнадстатеричной СС в десятичное СС
unsigned long long hex_to_dec(const char *in_hex){
    char a,*aPtr;
    unsigned int l;
    unsigned long long x,r;
 
    r = l = 0;
    aPtr = in_hex;
    if(aPtr == NULL) return 0;
    l = strlen(aPtr);
    if(l > 0 && l <= 16){
        l -= 1;
        while(*aPtr){
            a = *aPtr;
            if(a >= 0x41 && a <= 0x46) a -= 0x37;
            else if(a >= 0x61 && a <= 0x66) a -= 0x57;
            else if(a >= 0x30 && a <= 0x39) a -= 0x30;
            if(l > 1){
                x = 16;
                for(int j=l-1; j>0; j--) x = x * 16;
                r += a * x;
            } else if(l) r += a * 16;
            else r += a;
            aPtr++;
            l--;
        }
    }
    return r;
}
 
// Перевод десятичной СС в двойничное СС
int dec_to_bin(const unsigned long long dec,char *out_bin,const size_t size){
    char t,*aPtr,*bPtr;
    unsigned long long j;
 
    j = dec;
    aPtr = out_bin;
    bPtr = aPtr;
    if(((dec <= 0xFFFFFFFF && size == 32) || size == 64) && aPtr != NULL){
        while(j){
            *aPtr = '1';
            if((j%2) == 0) *aPtr = '0';
            aPtr++;
            j /= 2;
        }
        *aPtr = '\0';
        aPtr--;
        while(bPtr < aPtr){
            t = *aPtr;
            *aPtr = *bPtr;
            *bPtr = t;
            bPtr++;
            aPtr--;
        }
    } else return 0;
    return 1;
}
 
// Перевод десятчиной СС в шестнадцатеричное СС
int dec_to_hex(const unsigned long long dec,char *out_hex,const size_t size){
    unsigned int l;
    unsigned long long a,b,c;
    char t,*aPtr,*bPtr;
 
    aPtr = out_hex;
    bPtr = aPtr;
    if(((dec <= 0xFFFFFFFF && size == 32) || size == 64) && aPtr != NULL){
        a = c = dec;
        while(a > 0){
            a /= 16;
            b = a;
            a *= 16;
            a = c - a;
            switch(a){
                case 10: t = 'A'; break;
                case 11: t = 'B'; break;
                case 12: t = 'C'; break;
                case 13: t = 'D'; break;
                case 14: t = 'E'; break;
                case 15: t = 'F'; break;
                default: if(a >= 0 && a <= 9)
                            t = a + 0x30;
                         break;
            }
            c = a = b;
            *(aPtr++) = t;
        }
        *aPtr = '\0';
        aPtr--;
        while(bPtr < aPtr){
            t = *aPtr;
            *aPtr = *bPtr;
            *bPtr = t;
            aPtr--;
            bPtr++;
        }
    } else return 0;
    return 1;
}
 
int main()
{
    const char *in_bin = "1111111111111111111111111111111111111111111111111111111111111111";
    const char *in_hex = "FFFFFFFFFFFFFFFF";
    char out_bit[64] = {0};
    char out_hex[16] = {0};
    const unsigned long long in_dec = 0xFFFFFFFFFFFFFFFF;
 
    dec_to_bin(in_dec,out_bit,64/*32-64bits*/);
    printf("%s(%d)\n",out_bit,strlen(out_bit));
    printf("%lld\n",hex_to_dec(in_hex));
    printf("%lld\n",bin_to_dec(in_bin));
    dec_to_hex(in_dec,out_hex,64/*32-64bits*/);
    printf("%s(%d)\n",out_hex,strlen(out_hex));
    return 0;
}
Так что, кому помог решить данную задачу - рад был помочь.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.03.2020, 14:50
Ответы с готовыми решениями:

Перевод из одной системы счисления в другую
Помогите разобраться с переводом из любой системы счисления в любую. Хотел составить программу типа: Основание системы (вход): 15 ...

Перевод из одной системы счисления в другую
Приветствую, дали задание написать программу которая при вводе числа в 34-ричной системе счисления переводит это число в 14-ричную, голову...

Перевод из одной системы счисления в другую
Может кто подскажет ссылки где можно почитать про перевод чисел из однйо системы счисления в другую? К примеру из двоичной в...

1
Злостный нарушитель
 Аватар для Verevkin
10349 / 5767 / 1271
Регистрация: 12.03.2015
Сообщений: 26,637
10.03.2020, 15:26
Позравляю. Ты изобрёл велосипед.
С квадратными колёсами, но зато без педалей и сиденья.

Добавлено через 10 минут
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
// функция переводит число N в строку по основанию системы счисления В,
// дополняя слева нулями до длины А.
char* int2numb(int N, uint8_t A, uint8_t B, char* buff)
{
  int idx = 0;
  char digit, temp[8 * sizeof(N) + 1];
  memset(temp, 0, sizeof(temp));
 
  // преобразование
  do
  {
    digit = N % B;
    N /= B;
    temp[idx++] = (digit > 9) ? digit + 55 : digit + 48;
  } while (N);
 
  // дополнение нулями до заданной длины
  while (strlen(temp) < A) temp[idx++] = 0x30;
 
  temp[idx] = 0;
  strcpy(buff, strrev(temp));
  return buff;
}
 
// преобразование строки как числа системы счисления с основанием (1 < b < 37) 
// в целое без знака.
unsigned numb2uint(const char* s, uint8_t b)
{
  unsigned result = 0, p = 1;
  auto len = strlen(s);
  
  while (len--)
  {
    char symbol = toupper(s[len]);
    result += p * (symbol - (symbol > '@' ? 0x37 : 0x30));
    p *= b;
  }
  
  return result;
}
Кликните здесь для просмотра всего текста


0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.03.2020, 15:26
Помогаю со студенческими работами здесь

Перевод из одной системы счисления в другую
Составить программу перевода натурального числа из позиционной системы счисления с основанием m в позиционную систему счисления с...

Перевод из одной системы счисления в другую
помогите перевести из 8 ричной системы счисления в 16 ричную ----&gt; Перевод из системы по основанию 8 в систему по основанию 16 ...

Перевод из одной системы счисления в другую.
Мне задали сделать калькулятор для программиста на языке С. В нем требуется выполнение операций только целые числа, 4 арифметических...

Перевод из одной системы счисления в другую
перевод чисел(в том числе с дробной частью) из сс q в сс p.(q, p от 2 до 16) помогите протестить: #include &lt;iostream&gt; #include...

Перевод с одной системы счисления в другую
Приветствую вас, товарищи программисты. Помогите пожалуйста. Не могу решить, маленькую проблемку. Как сделать так, что-бы при вводе...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru