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

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

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

Given a number, find the sum of its digits.

Examples : 

Input: n = 687
Output: 21

Input: n = 12
Output: 3

Follow the below steps to solve the problem:

  • Get the number
  • Declare a variable to store the sum and set it to 0
  • Repeat the next two steps till the number is not 0
  • Get the rightmost digit of the number with help of the remainder ‘%’ operator by dividing it by 10 and adding it to the sum.
  • Divide the number by 10 with help of ‘/’ operator to remove the rightmost digit.
  • Print or return the sum

Below is the implementation of the above approach:

C++

#include <bits/stdc++.h>

using namespace std;

class gfg {

public:

    int getSum(int n)

    {

        int sum = 0;

        while (n != 0) {

            sum = sum + n % 10;

            n = n / 10;

        }

        return sum;

    }

};

int main()

{

    gfg g;

    int n = 687;

    cout << g.getSum(n);

    return 0;

}

C

#include <stdio.h>

int getSum(int n)

{

    int sum = 0;

    while (n != 0) {

        sum = sum + n % 10;

        n = n / 10;

    }

    return sum;

}

int main()

{

    int n = 687;

    printf(" %d ", getSum(n));

    return 0;

}

Java

import java.io.*;

class GFG {

    static int getSum(int n)

    {

        int sum = 0;

        while (n != 0) {

            sum = sum + n % 10;

            n = n / 10;

        }

        return sum;

    }

    public static void main(String[] args)

    {

        int n = 687;

        System.out.println(getSum(n));

    }

}

Python3

def getSum(n):

    sum = 0

    while (n != 0):

        sum = sum + int(n % 10)

        n = int(n/10)

    return sum

if __name__ == "__main__":

    n = 687

    print(getSum(n))

C#

using System;

class GFG {

    static int getSum(int n)

    {

        int sum = 0;

        while (n != 0) {

            sum = sum + n % 10;

            n = n / 10;

        }

        return sum;

    }

    public static void Main()

    {

        int n = 687;

        Console.Write(getSum(n));

    }

}

PHP

<?php

function getsum($n)

{

    $sum = 0;

    while ($n != 0)

    {

        $sum = $sum + $n % 10;

        $n = $n/10;

    }

    return $sum;

}

$n = 687;

$res = getsum($n);

echo("$res");

?>

Javascript

<script>

function getSum(n)

{

    var sum = 0;

    while (n != 0) {

        sum = sum + n % 10;

        n = parseInt(n / 10);

    }

    return sum;

}

var n = 687;

document.write(getSum(n));

</script>

Time Complexity: O(log N)
Auxiliary Space: O(1)

How to compute in a single line?

The below function has three lines instead of one line, but it calculates the sum in one line using for loop. It can be made one-line function if we pass the pointer to the sum. 

Below is the implementation of the above approach:

C++

#include <bits/stdc++.h>

using namespace std;

class gfg {

public:

    int getSum(int n)

    {

        int sum;

        for (sum = 0; n > 0; sum += n % 10, n /= 10)

            ;

        return sum;

    }

};

int main()

{

    gfg g;

    int n = 687;

    cout << g.getSum(n);

    return 0;

}

C

#include <stdio.h>

int getSum(int n)

{

    int sum;

    for (sum = 0; n > 0; sum += n % 10, n /= 10)

        ;

    return sum;

}

int main()

{

    int n = 687;

    printf(" %d ", getSum(n));

    return 0;

}

Java

import java.io.*;

class GFG {

    static int getSum(int n)

    {

        int sum;

        for (sum = 0; n > 0; sum += n % 10, n /= 10)

            ;

        return sum;

    }

    public static void main(String[] args)

    {

        int n = 687;

        System.out.println(getSum(n));

    }

}

Python3

def getSum(n):

    sum = 0

    while(n > 0):

        sum += int(n % 10)

        n = int(n/10)

    return sum

if __name__ == "__main__":

    n = 687

    print(getSum(n))

C#

using System;

class GFG {

    static int getSum(int n)

    {

        int sum;

        for (sum = 0; n > 0; sum += n % 10, n /= 10)

            ;

        return sum;

    }

    public static void Main()

    {

        int n = 687;

        Console.Write(getSum(n));

    }

}

PHP

<?php

function getsum($n)

{

    for ($sum = 0; $n > 0; $sum += $n % 10,

                                  $n /= 10);

    return $sum;

}

$n = 687;

echo(getsum($n));

?>

Javascript

<script>

function getSum(n)

{

    let sum;

    for(sum = 0; n > 0;

        sum += n % 10,

        n = parseInt(n / 10))

        ;

    return sum;

}

let n = 687;

document.write(getSum(n));

</script>

Time Complexity: O(log N)
Auxiliary Space: O(1)

Sum of the digits of a given number using recursion:

Follow the below steps to solve the problem:

  • Get the number
  • Get the remainder and pass the next remaining digits
  • Get the rightmost digit of the number with help of the remainder ‘%’ operator by dividing it by 10 and adding it to the sum.
  • Divide the number by 10 with help of the ‘/’ operator to remove the rightmost digit.
  • Check the base case with n = 0
  • Print or return the sum

Below is the implementation of the above approach:

C++

#include <iostream>

using namespace std;

class gfg {

public:

    int sumDigits(int no)

    {

        if (no == 0) {

            return 0;

        }

        return (no % 10) + sumDigits(no / 10);

    }

};

int main(void)

{

    gfg g;

    cout << g.sumDigits(687);

    return 0;

}

C

#include <stdio.h>

int sumDigits(int no)

{

    if (no == 0) {

        return 0;

    }

    return (no % 10) + sumDigits(no / 10);

}

int main()

{

    printf("%d", sumDigits(687));

    return 0;

}

Java

import java.io.*;

class GFG {

    static int sumDigits(int no)

    {

        if (no == 0) {

            return 0;

        }

        return (no % 10) + sumDigits(no / 10);

    }

    public static void main(String[] args)

    {

        System.out.println(sumDigits(687));

    }

}

Python3

def sumDigits(no):

    return 0 if no == 0 else int(no % 10) + sumDigits(int(no/10))

if __name__ == "__main__":

    print(sumDigits(687))

C#

using System;

class GFG {

    static int sumDigits(int no)

    {

        return no == 0 ? 0 : no % 10 + sumDigits(no / 10);

    }

    public static void Main()

    {

        Console.Write(sumDigits(687));

    }

}

PHP

<?php

function sumDigits($no)

{

return $no == 0 ? 0 : $no % 10 +

                      sumDigits($no / 10) ;

}

echo sumDigits(687);

?>

Javascript

<script>

     function sumDigits(no)

     {

        if(no == 0){

          return 0 ;

        }

        return (no % 10) + sumDigits(parseInt(no/10)) ;

      }

      document.write(sumDigits(687));

</script>

Time Complexity: O(log N)
Auxiliary Space: O(log N)

Sum of the digits of a given number with input as string:

When the number of digits of that number exceeds 1019 , we can’t take that number as an integer since the range of long long int doesn’t satisfy the given number. So take input as a string, run a loop from start to the length of the string and increase the sum with that character(in this case it is numeric)

Follow the below steps to solve the problem:

  • Declare a variable sum equal to zero
  • Run a loop from zero to the length of the input string
    • Add the value of each character into the sum, by converting the character into it’s integer value
  • Return sum

Below is the implementation of the above approach:

C++14

#include <bits/stdc++.h>

using namespace std;

int getSum(string str)

{

    int sum = 0;

    for (int i = 0; i < str.length(); i++) {

        sum = sum + str[i] - 48;

    }

    return sum;

}

int main()

{

    string st = "123456789123456789123422";

    cout << getSum(st);

    return 0;

}

Java

import java.io.*;

class GFG {

    static int getSum(String str)

    {

        int sum = 0;

        for (int i = 0; i < str.length(); i++) {

            sum = sum + str.charAt(i) - 48;

        }

        return sum;

    }

    public static void main(String[] args)

    {

        String st = "123456789123456789123422";

        System.out.print(getSum(st));

    }

}

Python3

def getSum(n):

    sum = 0

    for i in n:

        sum = sum + int(i)

    return sum

if __name__ == "__main__":

    n = "123456789123456789123422"

    print(getSum(n))

C#

using System;

public class GFG {

    static int getSum(String str)

    {

        int sum = 0;

        for (int i = 0; i < str.Length; i++) {

            sum = sum + str[i] - 48;

        }

        return sum;

    }

    static public void Main()

    {

        String st = "123456789123456789123422";

        Console.Write(getSum(st));

    }

}

PHP

<?php

function getsum($str)

{

      $sum = 0;

        for ($i = 0; $i<strlen($str); $i++) {

            $sum = $sum + (int)$str[$i];

        }

    return $sum;

}

$str = "123456789123456789123422";

echo(getsum($str));

?>

Javascript

<script>

function getSum(str)

{

    let sum = 0;

    for (let i = 0; i < str.length; i++)

    {

        sum = sum + parseInt(str[i]);

    }

    return sum;

}

let st = "123456789123456789123422";

document.write(getSum(st));

</script>

Time Complexity: O(N)
Auxiliary Space: O(1)

Sum of the digits of a given number using tail recursion:

Follow the below steps to solve the problem:

  • Add another variable “Val” to the function and initialize it to ( Val = 0 )
  • On every call to the function add the mod value (n%10) to the variable as “(n%10)+val” which is the last digit in n. Along with passing the variable n as n/10. 
  • So on the First call, it will have the last digit. As we are passing n/10 as n, It follows until n is reduced to a single digit. 
  • n<10 is the base case so When n < 10, then add the n to the variable as it is the last digit and return the val which will have the sum of digits

Below is the implementation of the above approach:

C++

#include <bits/stdc++.h>

using namespace std;

int sum_of_digit(int n, int val)

{

    if (n < 10) {

        val = val + n;

        return val;

    }

    return sum_of_digit(n / 10, (n % 10) + val);

}

int main()

{

    int num = 12345;

    int result = sum_of_digit(num, 0);

    cout << "Sum of digits is " << result;

    return 0;

}

C

#include <stdio.h>

int sum_of_digit(int n, int val)

{

    if (n < 10) {

        val = val + n;

        return val;

    }

    return sum_of_digit(n / 10, (n % 10) + val);

}

int main()

{

    int num = 12345;

    int result = sum_of_digit(num, 0);

    printf("Sum of digits is %d", result);

    return 0;

}

Java

import java.io.*;

import java.lang.*;

import java.util.*;

class sum_of_digits {

    static int sum_of_digit(int n, int val)

    {

        if (n < 10) {

            val = val + n;

            return val;

        }

        return sum_of_digit(n / 10, (n % 10) + val);

    }

    public static void main(String args[])

    {

        int num = 12345;

        int result = sum_of_digit(num, 0);

        System.out.println("Sum of digits is " + result);

    }

}

Python3

def sum_of_digit(n, val):

    if (n < 10):

        val = val + n

        return val

    return sum_of_digit(n // 10, (n % 10) + val)

if __name__ == "__main__":

    num = 12345

    result = sum_of_digit(num, 0)

    print("Sum of digits is", result)

C#

using System;

class GFG {

    static int sum_of_digit(int n, int val)

    {

        if (n < 10) {

            val = val + n;

            return val;

        }

        return sum_of_digit(n / 10, (n % 10) + val);

    }

    public static void Main()

    {

        int num = 12345;

        int result = sum_of_digit(num, 0);

        Console.Write("Sum of digits is " + result);

    }

}

Javascript

<script>

function sum_of_digit(n, val)

{

    if (n < 10)

    {

        val = val + n;

        return val;

    }

    return sum_of_digit(parseInt(n / 10),

    (n % 10) + val);

}

    let num = 12345;

    let result = sum_of_digit(num, 0);

    document.write("Sum of digits is " + result);

</script>

Output

Sum of digits is 15

Time Complexity: O(log N)
Auxiliary Space: O(log N)

Please write comments if you find the above codes/algorithms incorrect, or find better ways to solve the same problem.

Last Updated :
05 Dec, 2022

Like Article

Save Article

В этой статье мы разберем, как определяется сумма цифр числа при помощи кода на Python. Давайте сразу на простом примере поясним, что имеется в виду. Для вычисления такой суммы мы просто складываем цифры, которыми записано число, и при этом игнорируем их разряды. Допустим, у нас есть число 567. Мы можем вычислить сумму его цифр как 5 + 6 + 7 и получить ответ 18.

Наша цель состоит в том, чтобы определить сумму цифр числа, переданного в качестве входных данных в коде на Python.

Пример:

n = 54
Результат: 9

n = 121 
Результат: 4

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

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

Использование встроенных функций str() и int()

Чтобы преобразовать число в строку, используется функция str(). Для преобразования цифровых символов в целое число используется функция int().

Мы преобразуем число в строку и при помощи цикла перебираем все цифровые символы этой строки. В каждой итерации число, обозначаемое текущей цифрой, прибавляется к общей сумме.

Порядок алгоритма:

  1. Принимаем введенное пользователем значение числа
  2. Создаем переменную, в которой будем хранить результат
  3. Преобразуем число в строку
  4. Создаем цикл для итерации по полученной строке
  5. Внутри цикла преобразуем каждое строковое значение числа в целочисленный тип и добавляем в переменную, в которой хранится результат.

Код примера:

# Функция для получения суммы цифр числа
def getSum(n):
    
    sum = 0
    for digit in str(n): 
      sum += int(digit)      
    return sum
   
n = 569
print(getSum(n))

# Результат
# 20

Использование итерации

Здесь сумма цифр числа вычисляется при помощи цикла. Циклы используются для непрерывного выполнения определенного фрагмента кода. В языке Python циклы создаются при помощи операторов for и while.

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

Порядок алгоритма:

  1. Создаем функцию для нахождения суммы цифр числа n
  2. Объявляем переменную sum для хранения суммы цифр
  3. Создаем цикл while, который будет работать, пока значение n будет больше 0
  4. Остаток от деления числа на 10 прибавляем к переменной sum
  5. Меняем n на n // 10 (результат целочисленного деления на 10)
  6. Получаем число от пользователя
  7. Вызываем созданную ранее функцию и передаем ей в качестве аргумента полученное на предыдущем шаге число
  8. Выводим в консоль результат работы данной функции.

Пример кода:

# Функция для получения суммы цифр числа 
def getSum(n):
    
    sum = 0
    while (n != 0):
       
        sum = sum + (n % 10)
        n = n//10
       
    return sum
   
n = 569
print(getSum(n))

# Результат
# 20

Использование рекурсии

Рекурсия – это процесс решения задачи при помощи определения более простой версии этой самой задачи. Соответствующая функция называется рекурсивной. Использование рекурсии позволяет обойтись без применения циклов.

Алгоритм поиска суммы цифр числа при помощи рекурсии:

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

Пример кода:

# Функция для получения суммы цифр числа 
   
def sumDigits(no):
    return 0 if no == 0 else int(no % 10) + sumDigits(int(no / 10)) 
   
# Работа кода
n = 569
print(sumDigits(n))

# Результат
# 20

Использование метода sum()

Метод sum() используется для нахождения суммы всех чисел в переданном списке.

Сначала мы преобразуем число в строку при помощи метода str(). Затем мы разбиваем строку и преобразуем ее в список чисел при помощи методов split() и map() соответственно. А потом вычисляем сумму всех чисел данного списка при помощи метода sum().

Порядок алгоритма:

  1. Создаем функцию для нахождения суммы цифр числа n
  2. Преобразуем число в строку при помощи метода str()
  3. Затем разбиваем строку и преобразуем ее в список чисел при помощи методов split() и map() соответственно
  4. Для вычисления суммы чисел, входящих в список, вызывается метод sum().

Пример кода:

# Функция для получения суммы цифр числа
def getSum(n):
     
    strr = str(n)
    list_of_number = list(map(int, strr.strip()))
    return sum(list_of_number)
   
n = 569
print(getSum(n))

# Результат
# 20

Заключение

Сумма цифр числа — это сумма всех чисел, обозначаемых цифрами, которыми записано это число. Например, сумма цифр десятичного числа 9045 будет равна сумме чисел 9, 0, 4 и 5. То есть 9 + 0 + 4 + 5 = 18.

Найти сумму цифр числа можно разными способами. Мы разобрали использование встроенных функций, применение рекурсии и циклов.

Перевод статьи “Sum of Digits of a Number in Python”.

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

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

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

Например, сумма цифр числа 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

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

...
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 принимает каждое следующее значение списка.

Больше задач в PDF

Перейти к содержанию

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

Просмотров 8.4к. Обновлено 29 октября 2021

Если трехзначное число нацело разделить на 100, то получим число сотен, т.е. первую цифру этого числа.

Если найти остаток от деления на 10 любого целого числа, то этот остаток покажет число единиц в этом числе. Таким образом извлекается последняя цифра числа.

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

  1. Разделить число нацело на 10. Тем самым избавиться от последней цифры трехзначного числа, превратив его в двузначное.
  2. Найти остаток от деления полученного двузначного числа на 10. Этот остаток и будет средняя цифра первоначального трехзначного числа.

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

Pascal

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


var
n: integer;
a,b,c: byte;
begin
readln(n);
a := n div 100;
b := n div 10 mod 10;
c := n mod 10;
writeln('Сумма: ',a+b+c);
writeln('Произведение: ',a*b*c);
end.


Язык Си

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


#include

main() {
int n,a,b,c;
scanf("%d", &n);
a = n / 100;
b = n / 10 % 10;
c = n % 10;
printf("Сумма: %dn", a+b+c);
printf("Произведение: %dn", a*b*c);
}



349
Сумма: 16
Произведение: 108

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

Python

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


n = input("Введите трехзначное число: ")
n = int(n)

d1 = n % 10
d2 = n % 100 // 10
d3 = n // 100

print("Сумма цифр числа:", d1 + d2 + d3)
print("Произведение цифр числа:", d1 * d2 * d3)



Введите трехзначное число: 742
Сумма цифр числа: 13
Произведение цифр числа: 56

КуМир


алг сумма цифр
нач
ввод n
a := div(n,100)
b := mod(div(n,10),10)
c := mod(n,10)
вывод "Сумма: ", a+b+c, нс
вывод "Произведение: ", a*b*c, нс
кон


Basic-256


input n

a = n 100
b = n 10 % 10
c = n % 10

print a+b+c
print a*b*c


Обратите внимание на знак целочисленного деления. Это обратный слэш (), в то время как обычное деление обозначается обычным слэшем (/).

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