Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
1 / 1 / 0
Регистрация: 09.12.2023
Сообщений: 46

Ошибка в программе с системами счисления

21.02.2024, 11:42. Показов 1972. Ответов 42
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть программа, которая умножает и складывает числа в разных системах счисления. Почему-то в некоторых моментах пишет, что ответ 0 (Например в 9-ричной системе ввести 88888 и 88888)
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
#include <stdio.h>
#include <locale.h>
#include <stdlib.h>
 
#define _CRT_SECURE_NO_WARNINGS
#define MAX_LINE 16
 
int  to_base(int num, int base);       // десятичное -> число в СЧ по основанию base
int  decimal(int num, int base);       // число в СЧ по основанию base -> десятичное
void reverse(char a[], int size);      // разворачивает строку
void kr_itoa(int num, char s[], int base);     // чуть измененный аналог itoa K&R
void table_p(int base, char oper);     // таблица умножения (сложения)
void operato (int num1, int num2, char oper, int base);    // столбик
 
int main(void) {
    int base, num1, num2;
    setlocale(LC_ALL, "rus");
 
    printf("Основание системы счисления СЧ (3 - 9): ");
    if (scanf_s("%d", &base) != 1 || base < 3 || base > 9)
        return 1;
 
    table_p(base, 'x');
    table_p(base, '+');
 
    puts("");
    printf("Введите первое число в СЧ по основанию %d: ", base);
    if (scanf_s("%d", &num1) != 1 || num1 < 0)
        return 1;
 
    printf("Введите второе число в СЧ по основанию %d: ", base);
    if (scanf_s("%d", &num2) != 1 || num2 < 0)
        return 1;
 
    puts("\nУмножение:");
    operato(num1, num2, 'x', base);
 
    puts("\nСложение:");
    operato(num1, num2, '+', base);
 
    return 0;
}
// -------------------------------------------------------------
int to_base(int num, int base) {
    char buf[MAX_LINE];
    kr_itoa(num, buf, base);
    return atoi(buf);
}
// -------------------------------------------------------------
void reverse(char s[], int size) {
#define swap(a, b) { char t = a; a = b; b = t; }
    for (int i = 0, k = size - 1; i < k; i++, k--)
        swap(s[i], s[k]);
}
// -------------------------------------------------------------
int decimal(int num, int base) {
    int result = 0, power;
    for (power = 1; num > 0; num /= 10, power *= base)
        result += (num % 10) * power;
    return result;
}
// -------------------------------------------------------------
void kr_itoa(int num, char s[], int base) {
    int len;
    for (len = 0; num > 0; num /= base, len++)
        s[len] = '0' + (num % base);
    s[len] = '\0';
    reverse(s, len);
}
// -------------------------------------------------------------
void table_p(int base, char oper) {
    const char* s = (oper == '+') ? "сложения" : "умножения";
    printf("\nТаблица %s:\n%4c", s, ' ');
    for (int i = 1; i < base; i++)
        printf("%4d", i);
    puts("");
 
    for (int i = 1; i < base; i++) {
        printf("%4d", i);
        for (int k = 1; k < base; k++)
            printf("%4d", to_base((oper == '+') ? i + k : i * k, base));
        puts("");
    }
}
// -------------------------------------------------------------
void operato (int num1, int num2, char oper, int base) {
    int w, d = -2,
        width = MAX_LINE - 1,
        n1 = decimal(num1, base),
        n2 = decimal(num2, base);
    char line[MAX_LINE];
 
    for (w = 0; w < width; w++)
        line[w] = '-';
    line[w] = '\0';
 
    printf("%*d\n%*c%*d\n%s\n", w, num1, d, oper, w + d, num2, line);
    if (oper == '+')
        printf("%*d\n", w, to_base(n1 + n2, base));
    else {
        for (int n = num2; n > 0; n /= 10)
            printf("%*d\n", w--, to_base(n1 * (n % 10), base));
        printf("%s\n%*d\n", line, width, to_base(n1 * n2, base));
    }
}
// -------------------------------------------------------------
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.02.2024, 11:42
Ответы с готовыми решениями:

Ошибка в программе с системами счисления
Не прошу разбираться во всей программе, помогите только понять в чем ошибка... Суть такая: вводится основание системы счисления, потом...

работа с системами счисления
У меня в файле число: 0x00000000 Мне нужно его прочиатать да ещё и занести в переменную. Пожно с помошью char или std::string, а как ещё?...

Задача с системами счисления
Всех приветствую! Только сейчас зарегистрировался на форуме, так как стал нуждаться в помощи. Если Вам не сложно, то хотел бы попросить...

42
Злостный нарушитель
 Аватар для Verevkin
10878 / 5817 / 1288
Регистрация: 12.03.2015
Сообщений: 26,855
21.02.2024, 14:11
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от kom tancen Посмотреть сообщение
у меня же есть другая функция operato, в которой выводится умножение и сложение, не могу же я её заменить этим
Пачиму?
Цитата Сообщение от kom tancen Посмотреть сообщение
не ругайтесь пж
Мы ещо не начинали.
0
Модератор
Эксперт С++
 Аватар для zss
13789 / 10981 / 6492
Регистрация: 18.12.2011
Сообщений: 29,276
21.02.2024, 14:16
Цитата Сообщение от kom tancen Посмотреть сообщение
не могу же я её заменить этим
Не только можете но и должны
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
    printf("Введите первое число в СЧ по основанию %d: ", base);
    char c1[20];
    scanf_s("%s", c1,20);
    printf("Введите второе число в СЧ по основанию %d: ", base);
    char c2[20];
    scanf_s("%s", c2,20);
 
    puts("\nУмножение:");
    char result[20];
    operato(c1, c2, '*', base,result);
    puts(result);
 
    puts("\nСложение:");
    operato(c1, c2, '+', base,result);
    puts(result);
1
848 / 651 / 323
Регистрация: 24.02.2017
Сообщений: 2,297
21.02.2024, 14:17
kom tancen, навыкам расчетов в десятичной системе Вас учили в школе -так используйте это. Запишите представление числа по какому то основанию в виде строки. Перевидите это представление числа по выбранному основанию в десятичное число. Сложение и умножение столбиком - примеры есть в длинной арифметике. Результат переводим из десятичного в нужное основание.
0
737 / 704 / 110
Регистрация: 29.05.2015
Сообщений: 4,316
21.02.2024, 15:46
Цитата Сообщение от zss Посмотреть сообщение
вычисления можно делать не столбиком, а через двоичные числа в памяти компьютера.
Вычисления можно производить так же и через десятичные числа: преобразовывать троичное-в-десятичное, вычислять обычным калькулятором (компьютером), переводить результат обратно в троичное. Это самый простой способ. Вопрос в том, какое решение хочет увидеть препод - через преобразование в десятичное или троичный столбик?
0
848 / 651 / 323
Регистрация: 24.02.2017
Сообщений: 2,297
21.02.2024, 15:48
Цитата Сообщение от TheCalligrapher Посмотреть сообщение
2222223 * 2222223дает 22221000013.
Окончательный ответ: 2222223 * 2222223 = 2222210000013
0
Злостный нарушитель
 Аватар для Verevkin
10878 / 5817 / 1288
Регистрация: 12.03.2015
Сообщений: 26,855
21.02.2024, 15:54
Цитата Сообщение от alexu_007 Посмотреть сообщение
преобразовывать троичное-в-десятичное, вычислять обычным калькулятором (компьютером), переводить результат обратно в троичное.
Я тебе щас один умный вещ скажу... Только ты не обижайся...
0
737 / 704 / 110
Регистрация: 29.05.2015
Сообщений: 4,316
21.02.2024, 16:02
Цитата Сообщение от Verevkin Посмотреть сообщение
Я тебе щас один умный вещ скажу
Давай говори. Я слушаю.
0
Злостный нарушитель
 Аватар для Verevkin
10878 / 5817 / 1288
Регистрация: 12.03.2015
Сообщений: 26,855
21.02.2024, 16:09
Цитата Сообщение от alexu_007 Посмотреть сообщение
Давай говори. Я слушаю.
Вся информация в конпуктере хранится, передаётся и обрабатывается исключительно в двоичном виде. А не
Цитата Сообщение от alexu_007 Посмотреть сообщение
через десятичные числа
0
1 / 1 / 0
Регистрация: 09.12.2023
Сообщений: 46
21.02.2024, 18:04  [ТС]
Цитата Сообщение от zss Посмотреть сообщение
Не только можете но и должны
Я написала всё как вы прописали, но всё равно если ввести 88888*88888 в 9-ричной выводит что-то не то, вообще знаки какие-то
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
#include <stdio.h>
#include <locale.h>
#include <stdlib.h>
#include <string.h>
 
#define _CRT_SECURE_NO_WARNINGS
#define MAX_LINE 16
 
void reverse(char s[], int size) {
#define swap(a, b) { char t = a; a = b; b = t; }
    for (int i = 0, k = size - 1; i < k; i++, k--)
        swap(s[i], s[k]);
}
 
void kr_itoa(int num, char s[], int base) {
    int len;
    for (len = 0; num > 0; num /= base, len++)
        s[len] = '0' + (num % base);
    s[len] = '\0';
    reverse(s, len);
}
 
int to_base(int num, int base) {
    char buf[MAX_LINE];
    kr_itoa(num, buf, base);
    return atoi(buf);
}
 
void table_p(int base, char oper) {
    const char* s = (oper == '+') ? "сложения" : "умножения";
    printf("\nТаблица %s:\n%4c", s, ' ');
    for (int i = 1; i < base; i++)
        printf("%4d", i);
    puts("");
 
    for (int i = 1; i < base; i++) {
        printf("%4d", i);
        for (int k = 1; k < base; k++)
            printf("%4d", to_base((oper == '+') ? i + k : i * k, base));
        puts("");
    }
} 
 
void binary_to_base(int num, int base, char* str)
{
    int i = 0;
    while (num)
    {
        str[i++] = num % base + '0';
        num /= base;
    }
    str[i] = 0;
    reverse(str, strlen(str));
}
int base_to_binary(char* str, int base)
{
    int t = 0;
    for (int i = 0; str[i] != 0; i++)
    {
        t *= base;
        t += str[i] - '0';
    }
    return t;
}
 
void operato(char* str1, char* str2, char oper, int base, char* result)
{
    int num1 = base_to_binary(str1, base);
    int num2 = base_to_binary(str2, base);
    int num3 = oper == '+' ? num1 + num2 : num1 * num2;
    binary_to_base(num3, base, result);
}
 
int main(void) {
    int base, num1, num2;
    setlocale(LC_ALL, "rus");
 
    printf("Основание системы счисления СЧ (3 - 9): ");
    if (scanf_s("%d", &base) != 1 || base < 3 || base > 9)
        return 1;
 
    table_p(base, 'x');
    table_p(base, '+');
 
    puts("");
    printf("Введите первое число в СЧ по основанию %d: ", base);
    char c1[20];
    scanf_s("%s", c1, 20);
    printf("Введите второе число в СЧ по основанию %d: ", base);
    char c2[20];
    scanf_s("%s", c2, 20);
 
    puts("\nУмножение:");
    char result[20];
    operato(c1, c2, '*', base, result);
    puts(result);
 
    puts("\nСложение:");
    operato(c1, c2, '+', base, result);
    puts(result);
    return 0;
}
Добавлено через 18 минут
0
Злостный нарушитель
 Аватар для Verevkin
10878 / 5817 / 1288
Регистрация: 12.03.2015
Сообщений: 26,855
21.02.2024, 18:10
Цитата Сообщение от kom tancen Посмотреть сообщение
Я написала всё как вы прописали, но всё равно если ввести 88888*88888 в 9-ричной выводит что-то не то, вообще знаки какие-то
Вот так попробуй:
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
#include <stdio.h>
#include <locale.h>
#include <stdlib.h>
#include <stdint.h>
#include <string.h>
 
#define _CRT_SECURE_NO_WARNINGS
#define MAX_LINE 16
 
void reverse(char s[], int size) {
#define swap(a, b) { char t = a; a = b; b = t; }
    for (int i = 0, k = size - 1; i < k; i++, k--)
        swap(s[i], s[k]);
}
 
void kr_itoa(int num, char s[], int base) {
    int len;
    for (len = 0; num > 0; num /= base, len++)
        s[len] = '0' + (num % base);
    s[len] = '\0';
    reverse(s, len);
}
 
int to_base(int num, int base) {
    char buf[MAX_LINE];
    kr_itoa(num, buf, base);
    return atoi(buf);
}
 
void table_p(int base, char oper) {
    const char* s = (oper == '+') ? "сложения" : "умножения";
    printf("\nТаблица %s:\n%4c", s, ' ');
    for (int i = 1; i < base; i++)
        printf("%4d", i);
    puts("");
 
    for (int i = 1; i < base; i++) {
        printf("%4d", i);
        for (int k = 1; k < base; k++)
            printf("%4d", to_base((oper == '+') ? i + k : i * k, base));
        puts("");
    }
} 
 
void binary_to_base(uint64_t num, int base, char* str)
{
    int i = 0;
    while (num)
    {
        str[i++] = num % base + '0';
        num /= base;
    }
    str[i] = 0;
    reverse(str, strlen(str));
}
 
uint64_t base_to_binary(char* str, int base)
{
    uint64_t t = 0;
    for (int i = 0; str[i] != 0; i++)
    {
        t *= base;
        t += str[i] - '0';
    }
    return t;
}
 
void operato(char* str1, char* str2, char oper, int base, char* result)
{
    uint64_t num1 = base_to_binary(str1, base);
    uint64_t num2 = base_to_binary(str2, base);
    uint64_t num3 = oper == '+' ? num1 + num2 : num1 * num2;
    binary_to_base(num3, base, result);
}
 
int main(void) 
{
    int base, num1, num2;
    setlocale(LC_ALL, "rus");
 
    printf("Основание системы счисления СЧ (3 - 9): ");
    if (scanf("%d", &base) != 1 || base < 3 || base > 9)
        return 1;
 
    //table_p(base, 'x');
    //table_p(base, '+');
 
    puts("");
    printf("Введите первое число в СЧ по основанию %d: ", base);
    char c1[20];
    scanf("%s", c1);
    printf("Введите второе число в СЧ по основанию %d: ", base);
    char c2[20];
    scanf("%s", c2);
 
    puts("\nУмножение:");
    char result[20];
    operato(c1, c2, '*', base, result);
    puts(result);
 
    puts("\nСложение:");
    operato(c1, c2, '+', base, result);
    puts(result);
    return 0;
}
1
1 / 1 / 0
Регистрация: 09.12.2023
Сообщений: 46
21.02.2024, 18:17  [ТС]
Цитата Сообщение от Verevkin Посмотреть сообщение
Вот так попробуй:
ввожу систему счисления, потом первое число и меня кидает куда-то в stdio.h, не даёт ввести второе число... Visual Studio
0
1 / 1 / 0
Регистрация: 09.12.2023
Сообщений: 46
21.02.2024, 18:19  [ТС]
вот так вот
Цитата Сообщение от kom tancen Посмотреть сообщение
меня кидает куда-то в stdio.h
Миниатюры
Ошибка в программе с системами счисления  
0
Модератор
Эксперт С++
 Аватар для zss
13789 / 10981 / 6492
Регистрация: 18.12.2011
Сообщений: 29,276
21.02.2024, 18:24
kom tancen,
функции scanf и scanf_s - Это разные функции.
Если используете scanf_s, то надо указывать размер массива
Цитата Сообщение от zss Посмотреть сообщение
scanf_s("%s", c1,20);
0
Злостный нарушитель
 Аватар для Verevkin
10878 / 5817 / 1288
Регистрация: 12.03.2015
Сообщений: 26,855
21.02.2024, 18:27
Цитата Сообщение от kom tancen Посмотреть сообщение
Visual Studio
У меня нету MSVS: писать лабы в ней - это стральба из гаубицы по воробьям.
Пишу прям в браузере.

0
1 / 1 / 0
Регистрация: 09.12.2023
Сообщений: 46
21.02.2024, 18:37  [ТС]
Спасибо вам большое! Всё работает как надо

Добавлено через 1 минуту
Цитата Сообщение от Verevkin Посмотреть сообщение
писать лабы в ней - это стральба из гаубицы по воробьям
Преподаватель проверяет там, поэтому и нам так же нужно
0
Злостный нарушитель
 Аватар для Verevkin
10878 / 5817 / 1288
Регистрация: 12.03.2015
Сообщений: 26,855
21.02.2024, 18:39
Цитата Сообщение от kom tancen Посмотреть сообщение
Спасибо вам большое! Всё работает как надо
С тебя пиво.

Добавлено через 30 секунд
Цитата Сообщение от kom tancen Посмотреть сообщение
Преподаватель проверяет там, поэтому и нам так же нужно
Найди себе гетеросексуального препода.
1
1 / 1 / 0
Регистрация: 09.12.2023
Сообщений: 46
21.02.2024, 18:46  [ТС]
Цитата Сообщение от Verevkin Посмотреть сообщение
С тебя пиво
0
737 / 704 / 110
Регистрация: 29.05.2015
Сообщений: 4,316
21.02.2024, 20:45
Цитата Сообщение от Verevkin Посмотреть сообщение
Вся информация в конпуктере хранится, передаётся и обрабатывается исключительно в двоичном виде. А не
Я догадывался об этом. Но, задания компьютеру даёт человек. И программы для компьютера пишет человек. А человек как-то не очень дружит с двоичным видом. По крайней мере, в моей программе перевода из одной системы счисления в другую числа сперва переводятся в промежуточную десятичную.
0
Злостный нарушитель
 Аватар для Verevkin
10878 / 5817 / 1288
Регистрация: 12.03.2015
Сообщений: 26,855
21.02.2024, 20:51
Цитата Сообщение от alexu_007 Посмотреть сообщение
Но, задания компьютеру даёт человек. И программы для компьютера пишет человек.
И чо?
Цитата Сообщение от alexu_007 Посмотреть сообщение
По крайней мере, в моей программе перевода из одной системы счисления в другую числа сперва переводятся в промежуточную десятичную.
Да ты не понял ни хрена, что я сказать хотел. Человек пишет ТЕКСТ программы (исходник). А процессор конпуктера исполняет машинный код. На сигнальном уровне - это нули (низкий уровень) и единицы (высокий уровень). Никакой десятичной системы там нет.



Не морочай людям голову.
0
21.02.2024, 21:22

Не по теме:

Цитата Сообщение от alexu_007 Посмотреть сообщение
По крайней мере, в моей программе перевода из одной системы счисления в другую числа сперва переводятся в промежуточную десятичную.
Т.е. ты исходную строку конвертируешь в другую строку, а потом в третью?

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

Калькулятор с системами счисления
Может есть у кого исходник калькулятора с системами счисления?

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

Перевод между системами счисления
Есть ли в adnroid встроенная функция перевода из одной системы счисления в другую?

Решение Задачи с системами счисления
На уроках информатики Петя познакомился с системами счисления по различным основаниям. Петя также узнал, что для записи чисел могут...

Операции с восьмеричными системами счисления
Создать класс Oct1, который будет содержать число в 8-ричной системе (в отдельном поле – целая часть, в другом поле – дробная часть). ...


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

Или воспользуйтесь поиском по форуму:
40
Ответ Создать тему
Новые блоги и статьи
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики Контекст Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии Введение Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np class PlantAgent: def __init__(self, name, strategy, initial_biomass): self. name = name self. strategy = strategy # "greedy" (широколиственные) или. . .
сукцессия 9. Математика подлости: как растения предали грибных друзей
anaschu 27.06.2026
Статья 2. Глобальная фосфорная война: эволюционно-экономические механизмы распределения биомов Земли Введение: Экологический рынок как игра с нулевой суммой Традиционная экология долгое время. . .
сукцессия 8. Как я спорил с ИИ, которые - агенты растений и ненавистники грибов!
anaschu 27.06.2026
Статья 1. Хроники грибного восстания: как Сократов диалог разрушил академические догмы ИИ Введение: Синдром «цифрового учебника» Современные большие языковые модели (LLM) обладают колоссальным. . .
Главный вопрос моделирования сукцессии
anaschu 27.06.2026
главный вопрос. Если эктомикориза лучше добывает недоступный фосфор. И ее масса максимальна из всех. А широколиственный лес тоже имеет самую крутую биомассу. То почему не возникло их симбиоза? Это. . .
сукцессия 6. Питон реализация энилоджиковской модели, картинка про Центральную часть будущей модели
anaschu 26.06.2026
Етить. ИИ мне на основе моего старого файла R создал вот эту вот хмерь на пайтоне. Это уже новая модель, модель сукцессии грибной. потоки фосфора, азота. Углерода. 5 видов организмов. Я даже. . .
Как замкнутый ядерный цикл решит проблему недостатки фосфора? Био миграция фосфора со дна океана
anaschu 26.06.2026
Биологический лифт: Концепция подъема фосфора со дна океана с помощью ЗЯТЦ Предлагаю на обсуждение альтернативу тяжелому промышленному бурению океанического дна. Вместо сложной инженерии мы можем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru