Сложите цифры целого числа python

Найти сумму цифр числа в Python

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

Рас­смот­рим несколь­ко ва­ри­ан­тов ре­ше­ния этой за­да­чи. Про­стей­ший и самій оче­вид­ный спо­соб ре­ше­ния за­да­чи со­сто­ит в том, чтобы по­лу­чить каж­дую из цифр, со­став­ля­ю­щих дан­ное чис­ло. Для это­го по­сле­до­ва­тель­но бу­дем де­лить ис­ход­ное чис­ло n на 10 на­це­ло (на­хо­дит раз­ря­ды чис­ла). Де­ле­ние бу­дем вы­пол­нять в цик­ле, в ко­то­ром сра­зу же и бу­дем на­кап­ли­вать тре­бу­е­мую сум­му цифр — suma, а так­же за­по­ми­нать ре­зуль­тат де­ле­ния для но­вой ите­ра­ции цик­ла в ту же пе­ре­мен­ную n. Де­ле­ние (цикл) про­дол­жа­ет­ся по­ка чис­ло n не до­стигнет нуле­во­го зна­че­ния.

Но, мож­но обой­тись и без де­ле­ния. Для это­го за­дан­ное чис­ло n пре­об­ра­зу­ем в стро­ку s, а за­тем пе­ре­бе­рем в цик­ле по­сле­до­ва­тель­но все сим­во­лы (циф­ры) этой стро­ки. Но, чтобы их мож­но бы­ло сло­жить, они долж­ны быть пре­об­ра­зо­ва­ны в чис­ло­вые зна­че­ния — int(c). И даль­ше оста­ет­ся толь­ко вос­поль­зо­вать­ся функ­ци­ей sum(), чтобы сло­жить эти все циф­ры и по­лу­чить сум­му цифр чис­ла — suma.

Но, нам это­го ма­ло и мы идем даль­ше. А мож­но ли при ре­ше­нии этой за­да­чи из­ба­вить­ся от цик­ла. По­про­бу­ем. Ре­ше­ние бу­дет по­хо­же на преды­ду­щее, но цикл за­ме­ним встро­ен­ной функ­ци­ей map() при­ме­ня­е­мой к каж­до­му эле­мен­ту неко­то­ро­го объ­ек­та. В на­шем слу­чае это сим­во­лы стро­ки str(n), по­лу­чен­ной пре­об­ра­зо­ва­ни­ем ис­ход­но­го чис­ла в стро­ку и ее со­став­ля­ю­щих сим­во­лов в це­лые чис­ла.

Читайте также:  Как выглядит html кабель

Ес­ли код это­го при­ме­ра не со­всем по­ня­тен, то про­ще бу­дет по­нять сле­ду­ю­щий код — там ис­поль­зу­ем пре­об­ра­зо­ва­ние чис­ла в спи­сок из цифр и даль­ше про­хо­дим­ся по нему функ­ци­ей map()

Источник

Сумма и произведение цифр числа

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

Дано число. Найти сумму и произведение его цифр.

Например, сумма цифр числа 253 равна 10-ти, так как 2 + 5 + 3 = 10. Произведение цифр числа 253 равно 30-ти, так как 2 * 5 * 3 = 30.

В данном случае задача осложняется тем, что количество разрядов числа заранее (на момент написания программы) не известно. Это может быть и трехзначное число, как в примере выше, и восьмизначное, и однозначное.

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

При этом используются операции деления нацело и нахождения остатка. Если число разделить нацело на 10, произойдет «потеря» последней цифры числа. Например, 253 ÷ 10 = 25 (остаток 3). С другой стороны, эта потерянная цифра есть остаток от деления. Получив эту цифру, мы можем добавить ее к сумме цифр и умножить на нее произведение цифр числа.

Пусть n – само число, suma – сумма его цифр, а mult – произведение. Тогда алгоритм нахождения суммы и произведения цифр можно словесно описать так:

  1. Переменной suma присвоить ноль.
  2. Переменной mult присвоить единицу. Присваивать 0 нельзя, так как при умножении на ноль результат будет нулевым.
  3. Пока значение переменной n больше нуля повторять следующие действия:
    1. Найти остаток от деления значения n на 10, то есть извлечь последнюю цифру числа.
    2. Добавить извлеченную цифру к сумме и увеличить на эту цифру произведение.
    3. Избавиться от последнего разряда числа n путем деления нацело на 10.

    В языке Python операция нахождения остатка от деления обозначается знаком процента — % . Деление нацело — двумя слэшами — // .

    Код программы на языке Python

    n = int(input()) suma = 0 mult = 1 while n > 0: digit = n % 10 suma = suma + digit mult = mult * digit n = n // 10 print("Сумма:", suma) print("Произведение:", mult)
    253 Сумма: 10 Произведение: 30

    Python. Вычисление суммы и произведения цифр числа

    Изменение значений переменных можно записать в сокращенном виде:

    . while n > 0: digit = n % 10 suma += digit mult *= digit n //= 10 .

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

    Если число отрицательное, это не влияет на сумму его цифр. В таком случае достаточно будет использовать встроенную в Python функции abc , которая возвращает абсолютное значение переданного ей аргумента. Она превратит отрицательное число в положительное, и цикл while с его условием n > 0 будет работать как и прежде.

    Если число равно нулю, то по логике вещей сумма его цифр и их произведение должны иметь нулевые значения. Цикл срабатывать не будет. Поскольку исходное значение mult — это 1, следует добавить проверку на случай, если заданное число — это ноль.

    Программа, обрабатывающая все целые числа, может начинаться так:

    n = abs(int(input())) suma = 0 mult = 1 if n == 0: mult = 0 .

    Заметим, если в самом числе встречается цифра 0 (например, 503), то произведение всех цифр будет равно нулю. Усложним задачу:

    Вводится натуральное число. Найти сумму и произведение цифр, из которых состоит это число. При этом если в числе встречается цифра 0, то ее не надо учитывать при нахождении произведения.

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

    n = int(input()) suma = 0 mult = 1 while n > 0: digit = n % 10 if digit != 0: suma += digit mult *= digit n = n // 10 print("Сумма:", suma) print("Произведение:", mult)

    Обратим внимание, что заголовок условного оператора if digit != 0: в Python можно сократить до просто if digit: . Потому что 0 — это False . Все остальные числа считаются истиной.

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

    a = input() suma = 0 mult = 1 for digit in a: suma += int(digit) mult *= int(digit) print("Сумма:", suma) print("Произведение:", mult)

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

    n = input() suma = 0 mult = 1 for digit in n: if digit.isdigit(): suma += int(digit) mult *= int(digit) print("Сумма:", suma) print("Произведение:", mult)
    это3 чи3с9ло! Сумма: 15 Произведение: 81

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

    Глубокое знание языка Python позволяет решить задачу более экзотическими способами:

    import functools n = input() n = [int(digit) for digit in n] suma = sum(n) mult = functools.reduce(lambda x, y: x*y, n) print("Сумма:", suma) print("Произведение:", mult)

    Выражение [int(digit) for digit in n] представляет собой генератор списка. Если была введена строка «234» , будет получен список чисел: [2, 3, 4] .

    Встроенная функция sum считает сумму элементов переданного ей аргумента.

    Функция reduce модуля functools принимает два аргумента — лямбда-выражение и в данном случае список. Здесь в переменной x происходит накопление произведения, а y принимает каждое следующее значение списка.

    Источник

    Как найти сумму цифр числа в Python

    Обложка к статье

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

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

    Существует несколько способов нахождения суммы цифр в числе с использованием языка 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 является использование рекурсии. Рекурсивная функция — это функция, которая вызывает саму себя. Для решения этой задачи мы можем написать рекурсивную функцию, которая будет находить сумму цифр числа, путем разделения числа на цифры и вызова функции для каждой цифры. На каждом уровне рекурсии мы будем добавлять текущую цифру к сумме, а затем вызывать функцию с оставшейся частью числа.

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

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

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

    Источник

Оцените статью