Как найти сумму чисел четырехзначного числа питон

AndreyNill

Андрей Нилл

@AndreyNill

Новичок в сфере программирования

Найти сумму цифр четырёхзначного числа, поможете?

Дано четырёхзначное число. Найдите сумму его цифр.
Примеры
Ввод
Вывод
2020
4
Пример нахождения трёхзначного числа:
x = int(input())
x1 = x//100
x2 = (x//10)%10
x3 = x%10

Делать так же по этому примеру, операторы выше уровнем сайт не принимает


  • Вопрос задан

    более трёх лет назад

  • 9330 просмотров

print(sum(map(int, list(input()))))
Для любого кол-ва цифр в числе

Пригласить эксперта

number = str(input('Введите число: '))
sum_ = 0
for char in number:
    sum_+= int(char)
print(sum_)

работает с любыми числами, хоть тысячизначными

Переведите это число в строку и считайте отдельные ее элементы.

x = input()
summa = 0
for i in x:
    summa += int(i)
print(summa)


  • Показать ещё
    Загружается…

29 мая 2023, в 17:00

1000 руб./за проект

29 мая 2023, в 16:55

30000 руб./за проект

29 мая 2023, в 16:53

4000 руб./за проект

Минуточку внимания

Guest User

a guest

Aug 20th, 2018

3,586

0

Never

Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!

  1. # Запрос числа

  2. x = input ( «Введите 4-х значное число для nвычисления его суммы цифр:» )

  3. # х–число

  4. x = int ( x )

  5. # Выделение единиц

  6. a = x % 10

  7. # Выделение десятков

  8. b = ( x // 10 ) % 10

  9. # Выделение сотен

  10. c = (x // 100) % 10

  11. #Выделение тысяч

  12. d = x//1000

  13. # Вывод

  14. print ( a + b + c + d )

У меня есть число a = 1557

Как я могу узнать сумму этого числа, если мы берем каждую цифру отдельно (1 + 5 + 5 + 7)

entithat's user avatar

entithat

13.1k2 золотых знака19 серебряных знаков37 бронзовых знаков

задан 6 июл 2020 в 20:38

grimeca's user avatar

5

остаток от целочисленного деления на 10 это последняя цифра числа, просто в цикле складываем эти цифры, отбрасывая использованную цифру целочисленным делением на 10

def sum_of_digits(num):
    sum = 0
    while num > 0:
        sum += num % 10
        num //= 10
    return sum

print(sum_of_digits(1557)) # 18

ответ дан 6 июл 2020 в 20:54

Ildar's user avatar

IldarIldar

2,7921 золотой знак7 серебряных знаков24 бронзовых знака

1

В питоне это решается так

sum(map(int,str(12345)))

ответ дан 6 июл 2020 в 21:17

eri's user avatar

erieri

31.6k3 золотых знака26 серебряных знаков56 бронзовых знаков

Можно решить так:

print(sum([int(i) for i in list(str(int(input('a='))))]))

ответ дан 24 ноя 2021 в 15:22

MaxSUPER501's user avatar

2

На чтение 4 мин Просмотров 13.1к. Опубликовано

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

Содержание

  1. Способы нахождения суммы цифр в числе
  2. Способ 1: Использование цикла и операции взятия остатка от деления
  3. Способ 2: Преобразование числа в строку и использование цикла
  4. Способ 3: Использование рекурсии

Способы нахождения суммы цифр в числе

Существует несколько способов нахождения суммы цифр в числе с использованием языка Python. Один из самых простых способов — это использование цикла и арифметических операций. Второй способ — это преобразование числа в строку и последующее суммирование цифр с помощью цикла. Также можно использовать рекурсию для нахождения суммы цифр в числе. В этой статье мы рассмотрим все эти методы подробнее и покажем, как их использовать в Python.

Способ 1: Использование цикла и операции взятия остатка от деления

Один из наиболее простых способов найти сумму цифр в числе заключается в использовании цикла и операции взятия остатка от деления. Идея заключается в том, чтобы последовательно извлекать цифры из числа путем нахождения остатка от деления на 10 и добавлять их в сумму. Затем нужно целочисленно разделить число на 10 и продолжить процесс до тех пор, пока число не станет равным 0. Когда число станет равным 0, сумма цифр в числе будет содержаться в переменной суммы, которую мы и будем возвращать.

Приведём пример:

number = 12345
sum = 0

while number > 0:
    digit = number % 10
    sum += digit
    number //= 10

print("Сумма цифр числа:", sum)

В этом примере мы начинаем с числа number и инициализируем переменную sum нулевым значением. Затем мы запускаем цикл, который будет выполняться, пока number больше нуля.

На каждой итерации цикла мы используем операцию взятия остатка от деления на 10, чтобы получить последнюю цифру числа. Мы добавляем эту цифру к переменной sum, чтобы накапливать сумму цифр, и затем целочисленно делим number на 10, чтобы удалить последнюю цифру числа.

Когда цикл завершается, мы выводим значение переменной sum, которое представляет собой сумму цифр числа.

Способ 2: Преобразование числа в строку и использование цикла

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

Приведём пример:

num = 12345
sum_digits = 0
for digit in str(num):
    sum_digits += int(digit)

print("Сумма цифр числа", num, "равна", sum_digits)

В этом примере мы сначала определяем исходное число num. Затем мы инициализируем переменную sum_digits нулем, которая будет использоваться для хранения суммы цифр в числе. Мы затем используем цикл for для перебора каждой цифры в числе num, которое мы преобразуем в строку с помощью функции str(). Внутри цикла мы преобразуем каждую цифру обратно в целое число с помощью функции int() и добавляем его к сумме цифр sum_digits.

Наконец, мы выводим сообщение, которое отображает исходное число num и его сумму цифр.

Способ 3: Использование рекурсии

Еще одним способом нахождения суммы цифр числа в Python является использование рекурсии. Рекурсивная функция — это функция, которая вызывает саму себя. Для решения этой задачи мы можем написать рекурсивную функцию, которая будет находить сумму цифр числа, путем разделения числа на цифры и вызова функции для каждой цифры. На каждом уровне рекурсии мы будем добавлять текущую цифру к сумме, а затем вызывать функцию с оставшейся частью числа.

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

Приведём пример:

def sum_of_digits(n):
    if n < 10:
        return n
    else:
        return n % 10 + sum_of_digits(n // 10)

Эта функция принимает целое число n и рекурсивно находит сумму его цифр. Если число n меньше 10, то оно возвращается, так как оно само по себе является суммой своих цифр. В противном случае, функция находит последнюю цифру числа n с помощью операции взятия остатка от деления на 10 (n % 10), а затем вызывает себя же для нахождения суммы оставшихся цифр числа (sum_of_digits(n // 10)). Результатом работы функции является сумма всех цифр числа n.

Например, вызов sum_of_digits(123) вернет 6, так как сумма цифр числа 123 равна 1 + 2 + 3 = 6.

Сложить или перемножить цифры числа — задача, встречающаяся почти каждому программисту. Она позволяет не только проверить умение писать код и придумывать правильные алгоритмы, но и даёт возможность оценить синтаксис и функционал используемого языка.

Сумма цифр

Реализация программы на разных языках программирования мало чем отличается. Но из-за концепций и особенностей синтаксиса решение на языке Python получается более коротким и простым, чем, например, решение на C++.

Полный код программы нахождения суммы цифр числа на Python выглядит так:

num = int(input("Введите целое: "))
sum = 0
while (num != 0):
    sum = sum + num % 10
    num = num // 10
print("Сумма цифр числа равна: ", sum)

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

Во второй строке объявляется переменная, в которую будет записываться сумма. Переменная обязательна должна быть равна нулю. Иначе полученная сумма будет отличаться от реальной (некоторые люди путают сложение и произведение чисел, поэтому пишут не ноль, а единицу).

В цикле while происходит суммирование цифр. В 4 строке программа получает младший разряд числа. Например, если число равно 125, программа получает 5. Полученный младший разряд прибавляется к переменной суммы.

Строка 5: использованный младший разряд отбрасывается (делится на 10), то есть если было 125, то станет 12. Обязательно необходимо использовать целочисленное деление, то есть деление без остатка, иначе цифра не отбросится, а уйдет в дробную часть результата.

В 6 строке программа выводит результат суммирования в консоль. Пример выполнения:

Введите целое: 555
Сумма цифр числа равна: 15

В этом примере мы посчитали с помощью Python сумму цифр трёхзначного числа 555.

Произведение цифр

Программа на Python для вычисления произведения цифр числа имеет похожую структуру и принцип работы. Однако есть некоторые важные отличия:

num = int(input("Введите целое: "))
mult = 1
while (num != 0):
    mult = mult * (num % 10)
    num = num // 10
print("Произведение цифр равно: ", mult)

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

Важный момент, из-за того что оператор умножения имеет более высокий приоритет выполнения, чем оператор остатка от деления, выражение «num % 10» помещается в круглые скобки. Если не сделать этого, программа сначала будет умножать переменную mult на число и только потом брать от неё остаток.

Пример работы программы:

Введите целое: 55
Произведение цифр равно: 25

Частные случаи

Рассмотренные варианты программ являются самыми простыми. Однако существует ещё много частных случаев.

Число задано строкой

Когда программа получает ввод с помощью input, интерпретатор автоматически присваивает переменной строковый тип, если попытаться использовать эту переменную в вычислениях, возникнет ошибка.

В рассмотренных скриптах эта проблема была решена следующим образом:

num = int(input("Введите целое: "))

Оператор input помещается в функцию int, которая преобразует полученную строку к целому числу. В некоторых случаях бывает удобнее не преобразовывать число сразу, а сделать это непосредственно перед вычислением. Пример такого случая представлен ниже.

Задано дробное

Если пользователь вводит дробное число, стандартная реализация перестаёт работать. Дробная часть не учитывается, т.к. в программе происходит деление на 10. Даже если преобразовывать введенное число к целому с помощью  int, то будут отброшены все дробные цифры.

Рассмотрим программу для вычисления произведения цифр дробного числа (аналогично с суммой):

num = input("Введите дробное: ")
# разделим введённое (тип данных строка) на две части
x = num.split(".") 
a = int(x[0]) # целая часть
b = int(x[1]) # дробная часть
mult = 1
while (a != 0): # перемножаем числа целой части
    mult = mult * (a % 10)
    a = a // 10
while (b != 0): # перемножаем числа дробной части
    mult = mult * (b % 10)
    b = b // 10
print("Произведение цифр равно:", mult)

Пример выполнения программы:

Введите дробное: 55.5
Произведение цифр равно: 125

Эта программа правильно вычисляет произведение цифр любого числа:

  • Целое.
  • Дробное > 1.
  • Дробное < 1.

Реализация программы специально была сделана через строки, с помощью функции split введённое число делится на дробную и целую части. Дробная часть обрабатывается также, как и целая.

При приведении к действительному

Подход, описанный выше выбран потому, что из-за неточного представления десятичных дробей в двоичном виде (в котором работает компьютер), реальное представление числа отличается от ожидаемого. В итоге, если пользователь вводит число 0.55, то если привести её к действительному числу с помощью float, в переменную записывается значение 0.54999…8. В итоге, результат получается неточным, если ограничить количество итераций цикла, либо цикл является бесконечным, пример:

num = float(input("Введите дробное: ")) # Преобразуем строку в дробное
a = int(num) # целая часть, например, 5
b = num - int(num) # дробная часть, например, 0.55
print("a =", a)
print("b =", b)
mult = 1
while (a != 0): # перемножаем числа целой части
    mult = mult * (a % 10)
    a = a // 10
while (b != 0): # b никогда не будет равно 0
    mult = mult * int(b*10) # 0.55 * 10 = 5.5, int(5.5) = 5
    b = b * 10 - int(b * 10)
print("Произведение цифр равно:", mult)

Если бы в переменной реально было бы записано значение 5.55, то программа работала бы нормально. Однако в переменную b на самом деле помещается 0,54999… Это приводит к бесконечному выделению и отбрасыванию старшего разряда.

Вот пример вывода полученной программы:

Введите дробное: 5.55
a = 5
b = 0.5499999999999998
Произведение цифр равно: 0

Программа вывела переменную b, как 0.5499999999999998, после умножения на 10, её значение уже будет равно 5.499999999999998. Если вычесть из этого числа 5, то получим 0.4999999999999982. На конце добавилась цифра 2!

Таким образом прошло много итераций и в итоге b стало равно 0. В ходе перемножений среди цифр из которых состояло b были и нули. Поэтому результат равен 0.

Понравилась статья? Поделить с друзьями:
  • Как найти выборочное среднее задачи
  • Как найти двоеточие в русском языке
  • Как составить формулы высших оксидов по периодической системе менделеева
  • Как в симс 3 найти оленя
  • Как составить утвердительное предложение в английском языке в паст симпл