0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28

Арифметические операции над числами

02.02.2017, 13:57. Показов 4171. Ответов 19
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пытаюсь написать программу, производящую арифметические операции над числами, которые не входят в стандартный диапазон. Суть: каждое число представляется в строковой форме и посимвольно производятся операции с каждой цифрой этих чисел. Проблема состоит в том, что числа одинаковой длины складывает нормально. Но, если числа имеют разную длину, то начинаются ошибки. Например: 2+99 выводит 111.
Python
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
print('Какую операцию проводить с числами?')
print('(ввести: +, -, * или /):')
operation = input()
first_number = str(input('Введите первое число: '))
first_number = first_number[::-1]
second_number = str(input('Введите второе число: '))
second_number = second_number[::-1]
makeshift = str()
result = str()
 
if len(first_number) > len(second_number):
    makeshift = first_number
    first_number = second_number
    second_number = makeshift
    
calculate = 0
transposition = 0
if operation == '+':
    for i in range(0, len(second_number)):
        if i < len(first_number):
            calculate = int(first_number[i]) + int(second_number[i]) + transposition
        else:
            calcuate = int(second_number[i]) + transposition
        result += str(calculate % 10)
        transposition = calculate // 10
    result += str(transposition)
    result = result[::-1]
print(result)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.02.2017, 13:57
Ответы с готовыми решениями:

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

Арифметические действия над числами
Арифметические действия над числами обозначены следующими символами: «+» − сложение, «-» − вычитание, «*» − умножение, «/»...

Арифметические операции с числами в разных сс
Написать программу, выполняющую арифметическую операцию над числами в различных системах счисления: умножить любое число в двочиной сс на...

19
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 15:19
Цитата Сообщение от Slavjanych Посмотреть сообщение
арифметические операции над числами, которые не входят в стандартный диапазон.
Это какие?
0
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28
02.02.2017, 15:27  [ТС]
Это предполагается не в питоне использовать, но, например, и в паскале алгоритм пойдёт. Там ограничения по диапазонам. Просто, мне проще на питоне писать
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 15:43
Slavjanych, не понимаю.
Так про какие числа речь?
Какие-такие числа можно использовать в Паскале, но нельзя в Питоне?
0
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28
02.02.2017, 15:49  [ТС]
Все можно. Дело в диапазоне. Паскаль, например, не потянет число, которое больше 1..+2*1063 -1.
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 16:02
Slavjanych, ну так объясните про диапазон.
Насколько я помню, Паскаль оперирует с теми же числами, с которыми оперирует процессор.

Питон в этом отношении более гибок. У него и встроеные типы с собственным управлением, и есть сторонние пакеты для работы с ваще большими числами. Правда, быстро такие числа работать не могут.

Да, вы в курсе, что у разных типов чисел разный диапазон? У float-ов диапазон, конечно, побольше будет, но там может точность хромать.
0
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28
02.02.2017, 16:04  [ТС]
Я пишу программу для работы только с целыми числами
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 16:07
Slavjanych, хорошо.
И каким диапазоном вы, думаете, ограничены, а какой вам нужен?
0
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28
02.02.2017, 16:09  [ТС]
Вопрос, изначально, вообще, стоял другой. Я не могу понять, где в коде ошибка, из-за которой неправильно считает
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 16:14
Slavjanych, от того, какой диапазон вам нужен, зависит, а нужно ли вам вообще это писать.
Может, хватит встроеных питоновских типов. Может, имеет смысл заюзать готовый сторонний пакет, вроде был какой-то для Питона, bigint или что-то типа того.
0
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28
02.02.2017, 16:18  [ТС]
Планируется использование диапазонов от https://www.cyberforum.ru/cgi-bin/latex.cgi?-2*{10}^{-150}..2*{10}^{150}-1
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 16:23
Slavjanych, в инете пацаны гутарят - целые в Питоне неограничены.
Я сейчас проверил ваш диапазон - работает, без дополнительных телодвижений:
Code
1
2
print (2*10**150+1)
2000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001
0
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28
02.02.2017, 16:25  [ТС]
А паскаль не поймёт такой диапазон уже, на сколько я знаю
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 16:26
Slavjanych, паскаль не поймёт, да.
То есть вы хотите написать свой класс для больших чисел на питоне, чтобы потом переписать его на паскале?
0
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28
02.02.2017, 16:30  [ТС]
Именно так. На питоне мне писать попроще. Синтаксис простой

Добавлено через 2 минуты
Главное - алгоритм разработать. В питоне для меня это легче
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 16:31
Slavjanych, ну что ж, безумству храбрых поём мы песню.
Паскаль - мёртвый язык, и писать что-то под него я считаю пустой тратой времени.
Если всё же очень хочется - то в первую очередь надо искать готовые решения для паскаля, наверняка вы не первый, кто столкнулся с этой проблемой.

Добавлено через 1 минуту
https://www.google.by/webhp?q=... for+pascal
0
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28
02.02.2017, 16:31  [ТС]
Это понятно, что мёртвый. Но преподу только он нужен
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 16:50
Slavjanych, посмотрел код, какой-то странный алгоритм у вас.
Тут по соседству похожую задачу спрашивали, про умножение многочленов. Просто у вас не иксы, а десятки.
Работа со списками в Python
Но в целом подход сохраняется.
1
0 / 0 / 0
Регистрация: 04.06.2014
Сообщений: 28
02.02.2017, 16:52  [ТС]
dondublon, спасибо)
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
02.02.2017, 17:10
А, вам же сложение нужно? Тогда так:
Python
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
a = '256'
b = '1024'
 
def plus(first, second):
    # after all, it well be reversed
    maxlen = max(len(first), len(second))
    minlen = min(len(first), len(second))
    zero_diff = '0' * (maxlen - minlen)
    if len(first) > len(second):
        second = zero_diff + second
    else:
        first = zero_diff + first
    # it will be reversed
    result_buf = [0] * (maxlen + 1)
 
    for pos, (ia, ib) in enumerate(list(zip(first, second))[::-1]):
        res = int(ia) + int(ib)
        if res < 10:
            result_buf[pos] += res
        else:
            result_buf[pos] += res - 10
            result_buf[pos+1] += 1
 
    result_buf.reverse()
    return ''.join(str(digit) for digit in result_buf)
 
 
print(plus(a, b))
Добавлено через 34 секунды
Считать цифры начинаем от конца, а не от начала. Если от начала - легко запутаться.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.02.2017, 17:10
Помогаю со студенческими работами здесь

Операции над числами
Как разбить число на составляющие цифры и каждую из них вынести в список как тип данных int

Арифметические операции
Здравствуйте, нужна помощь. Допустим переменная A изначально = &quot;2+2&quot; нужно вычислить результат и записать его в другую переменную....

Арифметические операции
Описать функцию Calc(A, B, Op) вещественного типа, выполняющую над ненулевыми вещественными числами A и B одну из арифметических операций и...

Арифметические операции
1) Переменной a присвойте значение 23, переменной b - 7.5, переменной c - &quot;hello&quot; 2) Измените предыдущее значение переменной a, увеличив...

Задача на арифметические операции
Улитка ползет по вертикальному шесту высотой h метров, поднимаясь за день на x метров, а за ночь спускаясь на y метров. На какой день...


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

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

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru