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

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

21.02.2024, 11:42. Показов 1969. Ответов 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
Модератор
Эксперт С++
 Аватар для zss
13789 / 10981 / 6492
Регистрация: 18.12.2011
Сообщений: 29,276
22.02.2024, 06:32
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от alexu_007 Посмотреть сообщение
числа сперва переводятся в промежуточную десятичную
Вот это Вы считаете переводом в десятичную:
Цитата Сообщение от kom tancen Посмотреть сообщение
C++
1
2
3
4
5
6
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;
}
Эта функция берет целое ДВОИЧНОЕ число num
и превращает в другое целое ДВОИЧНОЕ число result.
0
737 / 704 / 110
Регистрация: 29.05.2015
Сообщений: 4,316
22.02.2024, 07:14
Цитата Сообщение от zayats80888 Посмотреть сообщение
Т.е. ты исходную строку конвертируешь в другую строку, а потом в третью?
У меня есть программа уже написаная для конвертации из одной системы счисл. в другую. С её помощью я в два действия решил 22222(3) * 22222(3). Сперва конверт. свою сист. счисл. в десятичную, можешь в hex, как удобно. Потом умножаешь и конверт. обратно в свою сист.счисл. Написать такой код дело 10-ти минут, тем более что код конвертации уже есть.
Миниатюры
Ошибка в программе с системами счисления  
0
848 / 651 / 323
Регистрация: 24.02.2017
Сообщений: 2,297
22.02.2024, 09:54
Цитата Сообщение от Verevkin Посмотреть сообщение
На сигнальном уровне - это нули (низкий уровень) и единицы (высокий уровень).
Вот и Verevkin, в дебри полез.
Цитата Сообщение от Verevkin Посмотреть сообщение
Человек пишет ТЕКСТ программы (исходник)
, подает на вход в "черный ящик" этот исходник и на выходе из него получает нужный для него результат. Зачем знать с какими там единицами и нулями работает "черный ящик"? alexu_007,
прав,что
Цитата Сообщение от alexu_007 Посмотреть сообщение
человек как-то не очень дружит с двоичным видом.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.02.2024, 09:54

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
43
Ответ Создать тему
Новые блоги и статьи
сукцессия 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