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

Improve Article

Save Article

Like Article

  • Read
  • Discuss
  • Improve Article

    Save Article

    Like Article

    Given a number, we need to find sum of its digits using recursion.
    Examples: 
     

    Input : 12345
    Output : 15
    
    Input : 45632
    Output :20
              

    The step-by-step process for a better understanding of how the algorithm works. 
    Let the number be 12345. 
    Step 1-> 12345 % 10 which is equal-too 5 + ( send 12345/10 to next step ) 
    Step 2-> 1234 % 10 which is equal-too 4 + ( send 1234/10 to next step ) 
    Step 3-> 123 % 10 which is equal-too 3 + ( send 123/10 to next step ) 
    Step 4-> 12 % 10 which is equal-too 2 + ( send 12/10 to next step ) 
    Step 5-> 1 % 10 which is equal-too 1 + ( send 1/10 to next step ) 
    Step 6-> 0 algorithm stops 
    following diagram will illustrate the process of recursion 
     

    C++

    #include <bits/stdc++.h>

    using namespace std;

    int sum_of_digit(int n)

    {

        if (n == 0)

        return 0;

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

    }

    int main()

    {

        int num = 12345;

        int result = sum_of_digit(num);

        cout << "Sum of digits in "<< num

           <<" is "<<result << endl;

        return 0;

    }

    C

    #include <stdio.h>

    int sum_of_digit(int n)

    {

        if (n == 0)

           return 0;

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

    }

    int main()

    {

        int num = 12345;

        int result = sum_of_digit(num);

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

        return 0;

    }

    Java

    import java.io.*;

    class sum_of_digits

    {

        static int sum_of_digit(int n)

        {

            if (n == 0)

                return 0;

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

        }

        public static void main(String args[])

        {

            int num = 12345;

            int result = sum_of_digit(num);

            System.out.println("Sum of digits in " +

                               num + " is " + result);

        }

    }

    Python3

    def sum_of_digit( n ):

        if n == 0:

            return 0

        return (n % 10 + sum_of_digit(int(n / 10)))

    num = 12345

    result = sum_of_digit(num)

    print("Sum of digits in",num,"is", result)

    C#

    using System;

    class GFG {

        static int sum_of_digit(int n)

        {

            if (n == 0)

                return 0;

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

        }

        public static void Main()

        {

            int num = 12345;

            int result = sum_of_digit(num);

            Console.WriteLine("Sum of digits in " +

                               num + " is " + result);

        }

    }

    PHP

    <?php

    function sum_of_digit($n)

    {

        if ($n == 0)

            return 0;

        return ($n % 10 +

                sum_of_digit($n / 10));

    }

    $num = 12345;

    $result = sum_of_digit($num);

    echo("Sum of digits in " . $num . " is " . $result);

    ?>

    Javascript

    <script>

    function sum_of_digit(n)

    {

        if (n == 0)

        return 0;

        return (n % 10 + sum_of_digit(parseInt(n / 10)));

    }

    var num = 12345;

    var result = sum_of_digit(num);

    document.write( "Sum of digits in "+ num

       +" is "+result );

    </script>

    Output: 

    Sum of digits in 12345 is 15

    Besides writing (n==0 , then return 0) in the code given above we can also write it in this manner , there will be no change in the output .

    if(n<10) return n; By writing this there will be no need to call the function for the numbers which are less than 10 

    Time complexity : O(logn) where n is the given number. 

    Auxiliary space : O(logn) due to recursive stack space.
     

    Last Updated :
    16 Jun, 2022

    Like Article

    Save Article

    Описание задачи

    Программа принимает на вход число и при помощи рекурсии находит сумму всех цифр, из которых это число состоит.

    Решение задачи

    1. Создадим пустой список, в который будем записывать цифры данного числа.
    2. Определим рекурсивную функцию, которая будет принимать в качестве аргумента число.
    3. Далее, принимаем от пользователя число и передаем его этой функции в качестве аргумента.
    4. В рекурсивной функции базовое условие определено как равенство аргумента нулю. В этом случае программа выводит сформированный список, состоящий из всех цифр числа.
    5. В противном случае в список добавляется остаток от деления аргумента на 10, а затем снова вызывается эта же функция, в которую в качестве аргумента передается результат целочисленного деления на 10.
    6. Затем находится сумма элементов списка при помощи встроенной функции Python, а результат выводится на экран. Вместо встроенной в Python функции также можно использовать код, который мы приводили в этом же разделе ранее.
    7. Также для сравнения можно посмотреть, как мы решали ранее эту же задачу при помощи итераций.

    Исходный код

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

    l = []
    def sum_digits(b):
        if (b == 0):
            return l
        dig = b % 10
        l.append(dig)
        sum_digits(b // 10)
    n = int(input("Введите число: "))
    sum_digits(n)
    print(sum(l))

    Объяснение работы программы

    1. Создается переменная l, которая инициируется пустым списком.
    2. Определяется рекурсивная функция sum_digits(), принимающая в качестве аргумента число.
    3. В самой функции определяется базовое условие рекурсии. Оно состоит в равенстве аргумента функции 0. В этом случае функция возвращает сформированный рекурсивным образом список l.
    4. В противном случае в список добавляется остаток от деления аргумента на 10, а затем снова вызывается эта же функция, в которую в качестве аргумента передается результат целочисленного деления на 10.
    5. Далее мы вызываем функцию sum_digits(), а в качестве аргумента передаем введенное пользователем число n.
    6. Затем вычисленная сумма всех цифр числа выводится на экран.

    Результаты работы программы

    Пример 1:
    Введите число: 135
    9
     
    Пример 2:
    Введите число: 546
    15

    Дано натуральное число N. Вычислите сумму его цифр. Где я накосячил?
    P.S не нужно предлагать мне решение циклами. Меня интересует именно логика отработки моего кода. Почему именно мой код не отрабатывает?

    a = input()
    a = str(a)
    result = 0
    count = 0
    def summa_cifr(a, count, result):
        c = ''
        c = c + a[count]
        c = int(c)
        result = result + c
        if count < len(a):
            return summa_cifr(a,count+1, result)
        else:
            return result
    summa_cifr(a, count, result)
    print(result)
    

    MaxU - stand with Ukraine's user avatar

    задан 17 авг 2018 в 16:03

    Spartak's user avatar

    2

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

    Вот однострочное рекурсивное решение, работающее с целыми числами без преобразования в строки:

    def sum_digits(num):
        return num%10 + sum_digits(num//10) if num > 9 else num
    

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

    In [17]: sum_digits(123)
    Out[17]: 6
    
    In [18]: sum_digits(1234567)
    Out[18]: 28
    
    In [19]: sum_digits(8)
    Out[19]: 8
    

    ответ дан 17 авг 2018 в 20:20

    MaxU - stand with Ukraine's user avatar

    a = input()
    a = str(a)
    def summa_cifr(a, count, result):
        c = ''
        c = c + a[count]
        c = int(c)
        result = result + c
        if count < len(a)-1:
            return summa_cifr(a,count+1, result)
        else:
            return result
    print(summa_cifr(a, 0, 0))
    

    ответ дан 17 авг 2018 в 16:17

    Spartak's user avatar

    SpartakSpartak

    7941 золотой знак9 серебряных знаков27 бронзовых знаков

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

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

    57 / 30 / 13

    Регистрация: 24.06.2014

    Сообщений: 255

    Записей в блоге: 1

    1

    Рекурсия: количество цифр в числе, сумма цифр и реверс числа

    28.08.2014, 00:10. Показов 42976. Ответов 12


    Студворк — интернет-сервис помощи студентам

    Вот задание:
    Написать программу, которая запрашивает у пользователя целое число, на экран выводит сколько цифр в числе,
    их сумму и вывод цифр наоборот (пример: 4356 – 4 цифры, сумма: 4+3+5+6=18, вывод наоборот: 6534)
    Разработать рекурсивную функцию, которая решает эту задачу!

    Вопрос: Можно ли написать одну функцию для всего или нужно 3 функции?



    0



    1123 / 794 / 219

    Регистрация: 15.08.2010

    Сообщений: 2,185

    28.08.2014, 00:15

    2

    можно ухитриться и в одну запихнуть, можно 3 отдельных — проще, нагляднее, логичнее.



    0



    57 / 30 / 13

    Регистрация: 24.06.2014

    Сообщений: 255

    Записей в блоге: 1

    28.08.2014, 00:20

     [ТС]

    3

    Всё функции должны быть рекурсивными. Можно примеры?



    0



    MicM

    840 / 498 / 325

    Регистрация: 29.12.2009

    Сообщений: 1,106

    28.08.2014, 00:33

    4

    Лучший ответ Сообщение было отмечено EfimKR как решение

    Решение

    Цитата
    Сообщение от EfimKR
    Посмотреть сообщение

    вывод цифр наоборот

    C++
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    
    #include <iostream>
    using namespace std;
     
    void func (int n)
    {
        cout <<n%10;
        if (n/10!=0)
            func (n/10);
    }
     
    int main()
    {
        int n;
        cout <<"N = ";
        cin >> n;
        func (n);
    }

    Добавлено через 8 минут

    C++
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    
    //возвращает кол-во цифр в числе
    int count (int n)
    {
        if (n/10!=0)
            return 1+count(n/10);
        else
            return 1;
    }
     
    //возвращает сумму цифр числа
    int sum (int n)
    {
        if (n/10!=0)
            return n%10+sum(n/10);
        else
            return n%10;
    }



    2



    КОП

    28.08.2014, 00:36

    Не по теме:

    MicM, эх, не дали вы человеку самому понять рекурсию…



    0



    EfimKR

    57 / 30 / 13

    Регистрация: 24.06.2014

    Сообщений: 255

    Записей в блоге: 1

    28.08.2014, 10:02

     [ТС]

    6

    Цитата
    Сообщение от MicM
    Посмотреть сообщение

    C++
    1
    2
    3
    4
    5
    6
    7
    8
    
    //возвращает сумму цифр числа
    int sum (int n)
    {
       if (n/10!=0)
         return n%10+sum(n/10);
       else
         return n%10;
    }

    Эта функция не работает.

    Добавлено через 7 минут
    Ошибся, работает, проблема в другом.

    Добавлено через 3 минуты

    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
    
    /* Написать программу, которая запрашивает у пользователя целое число, на экран выводит сколько цифр в числе, 
    их сумму и вывод цифр наоборот (пример: 4356 – 4 цифры, сумма: 4+3+5+6=18, вывод наоборот: 6534) 
    Разработать рекурсивную функцию, которая решает эту задачу! */
     
    #include<iostream>
    using namespace std;
     
    int numb(int);
    int sum_numb(int);
    int revers(int);
     
     
    int main()
    {
        setlocale(0, "");
        int nNumb;
        
        cout<<"Введите целое числоn";
        cin>>nNumb;
     
        
        cout<<"n"<<nNumb<<"n";
        cout<<"количество цифр: "<<numb(nNumb);
        cout<<"nсумма цифр: "<<sum_numb(nNumb)<<endl;
        cout<<"вывод наоборот: "<<revers(nNumb);
        
        cout<<"n";
        return 0;
    }
     
    int numb(int n)
    {
        if (0 != n/10) return numb(n/10)+1;
        else return 1;
    }
    int sum_numb(int n)
    {
        if (n/10!=0)
            return n%10+sum_numb(n/10);
        else  return n%10;
    }
     
    int revers(int n)
    {
        cout<<n%10;
        if (0 != n/10) return revers(n/10);
    }

    Почему вывод наоборот выводит число перед текстом?



    0



    57 / 30 / 13

    Регистрация: 24.06.2014

    Сообщений: 255

    Записей в блоге: 1

    28.08.2014, 10:04

     [ТС]

    7

    Рекурсия: количество цифр в числе, сумма цифр и реверс числа



    0



    rikimaru2013

    2549 / 1208 / 358

    Регистрация: 30.11.2013

    Сообщений: 3,826

    28.08.2014, 10:09

    8

    C++
    1
    2
    3
    4
    
        cout<<"n"<<nNumb;
        cout<<"nколичество цифр: "<<numb(nNumb);
        cout<<"nсумма цифр: "<<sum_numb(nNumb);
        cout<<"nвывод наоборот: "<<revers(nNumb);



    0



    57 / 30 / 13

    Регистрация: 24.06.2014

    Сообщений: 255

    Записей в блоге: 1

    28.08.2014, 10:35

     [ТС]

    9

    rikimaru2013, таким образом 54321 будет записано сразу за 15.

    Добавлено через 27 секунд
    И ещё одно, почему программа дописывает 0 в конце числа наоборот?



    0



    MicM

    840 / 498 / 325

    Регистрация: 29.12.2009

    Сообщений: 1,106

    28.08.2014, 10:54

    10

    У меня ничего не дописывает

    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
    
    #include <iostream>
    using std::cout;
    using std::cin;
    using std::endl;
     
    void func (int n)
    {
        cout <<n%10;
        if (n/10!=0)
            func (n/10);
    }
     
    int count (int n)
    {
        if (n/10!=0)
            return 1+count(n/10);
        else
            return 1;
    }
     
    int sum (int n)
    {
        if (n/10!=0)
            return n%10+sum(n/10);
        else
            return n%10;
    }
     
    int main()
    {
        int n;
        cout <<"N = ";
        cin >> n;
        cout <<count(n) <<endl
             <<"Sum: " <<sum(n) <<endl;
        func (n);
    }

    Миниатюры

    Рекурсия: количество цифр в числе, сумма цифр и реверс числа
     



    1



    57 / 30 / 13

    Регистрация: 24.06.2014

    Сообщений: 255

    Записей в блоге: 1

    28.08.2014, 11:20

     [ТС]

    11

    MicM, это я примерно так-же решил. Меня другое интересовало, почему число перед текстом писало.

    С 0 также разобрался, его возвращала функция в main где он выводился. Решил сделав функцию реверса типа void.



    0



    -=ЮрА=-

    Заблокирован

    Автор FAQ

    28.08.2014, 14:49

    12

    Цитата
    Сообщение от EfimKR
    Посмотреть сообщение

    Вот задание:
    Написать программу, которая запрашивает у пользователя целое число, на экран выводит сколько цифр в числе,
    их сумму и вывод цифр наоборот (пример: 4356 – 4 цифры, сумма: 4+3+5+6=18, вывод наоборот: 6534)
    Разработать рекурсивную функцию, которая решает эту задачу!
    Вопрос: Можно ли написать одну функцию для всего или нужно 3 функции?

    — ну можно

    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
    
    #include <iostream>
    using namespace std;
     
    int recsplit(int num, int &sum, int &back);
     
    int main(){
        int n = 0;
        int num = 4567;
        int sum = 0;
        n = recsplit(num, sum, num);
        cout<<"  n = "<<n<<endl;
        cout<<"sum = "<<sum<<endl;
        cout<<"num = "<<num<<endl;
        return 0;
    }
     
    int recsplit(int num, int &sum, int &back){
        int n = 1;
        if( back == num )
            back = 0;
        else
            back *= 10;
        if( num % 10 )
        {
            back += (num % 10);
            sum  += (num % 10);
        }
        else
            sum  *= 10;
        if( num /= 10 )
            n += recsplit(num, sum, back);
        return n;
    }

    n = 4
    sum = 22
    num = 7654

    http://codepad.org/lig1H2pP



    2



    jurok_85

    365 / 321 / 219

    Регистрация: 21.02.2013

    Сообщений: 756

    28.08.2014, 14:51

    13

    а вот три в одном оцените:

    C++
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    
    #include <iostream>
    using namespace std;
     
     
    void rev_num(int num)
    {
        cout << num % 10 << " ";
        static int sum = 0, counter = 0;
        counter++;
        sum += num % 10;
        if(num/10)
        rev_num(num/10);
        else
        cout <<"n Kol-vo cifr: "<< counter
        << "n Summa cifr: " << sum;
    }
    int main()
    {
       int number = 123456;
     
       rev_num(number);
        return 0;
    }



    1



    IT_Exp

    Эксперт

    87844 / 49110 / 22898

    Регистрация: 17.06.2006

    Сообщений: 92,604

    28.08.2014, 14:51

    Помогаю со студенческими работами здесь

    Определить сколько цифр в заданном натуральном числе, и чему равна сумма его цифр
    Дано натуральное число n (n&lt;=100). Определить сколько цифр в числе n, чему равна сумма его цифр.

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

    Найти простые числа, чтобы сумма их цифр, а также сумма цифр следующего за ним числа, делилась на 7
    задание:&quot;найдите простые числа такие, чтобы сумма их цифр, а также сумма цифр следующего за ним…

    дано натуральное число N. Определить,во сколько раз произведение цифр числа больше суммы цифр.Найти количество чётных цифр в записи числа!!
    дано натуральное число N. Определить,во сколько раз произведение цифр числа больше суммы цифр.Найти…

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

    Или воспользуйтесь поиском по форуму:

    13

    Понравилась статья? Поделить с друзьями:

    Не пропустите также:

  • Найти работу через телеграмм как правильно
  • Как найти ноль на линии
  • Как найти сторону квадрата 4м2
  • Как найти удлинение первой пружины
  • Как найти абсолютное базисное отклонение

  • 0 0 голоса
    Рейтинг статьи
    Подписаться
    Уведомить о
    guest

    0 комментариев
    Старые
    Новые Популярные
    Межтекстовые Отзывы
    Посмотреть все комментарии