Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 30, средняя оценка - 4.63
Parilo
14 / 2 / 0
Регистрация: 18.11.2011
Сообщений: 90
#1

Написать рекурсивную функцию вычисления суммы цифр натурального числа - C++

27.10.2012, 13:06. Просмотров 5005. Ответов 5
Метки нет (Все метки)

Нужно написать рекурсивную функцию вычисления суммы цифр натурального числа.
Я написал нижеследующее что тоже работает, но это не рекурсивная функция, как написать рекурсивную?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
using namespace std;
int sumnum();
int sumnum (int a)
{ int d=0;
 while (a>0)
 { d+=a%10;
 a=a/10;}
 
 
 
return d; 
 
}
 int main ()
{ int g;
  cin >> g; 
  cout << sumnum (g);
 
 return 0;}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.10.2012, 13:06
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Написать рекурсивную функцию вычисления суммы цифр натурального числа (C++):

Написать рекурсивную функцию вычисления суммы цифр натурального числа - C++
Помоги написать код, пожалуйста. Написать рекурсивную функцию вычисления суммы цифр натурального числа.

Написать рекурсивную функцию вычисления суммы цифр натурального числа - C++
Вот задача: Написать рекурсивную функцию вычисления суммы цифр натурального числа. Вот что я написал: #include&lt;iostream&gt; ...

Написать рекурсивную функцию для вычисления суммы цифр натурального числа, введенного пользователем - C++
Нужно написать рекурсивную функцию для вычисления суммы цифр натурального числа, введенного пользователем. Все это надо реализовать с...

Написать рекурсивную функцию вычисления количества цифр натурального числа - C++
Как написать рекурсивную функцию вычисления количества цифр натурального числа?

Написать рекурсивную функцию вычисления количества цифр натурального числа - C++
Написать рекурсивную функцию вычисления количества цифр натурального числа. Помогите пожалуйста, сижу на паре, сейчас лаба идет.

Написать рекурсивную функцию вычисления количества цифр натурального числа(исправить код) - C++
Написать рекурсивную функцию вычисления количества цифр натурального числа. Я вот написал, но программа считает только первые 9 чисел!...

5
David Sylva
1288 / 950 / 51
Регистрация: 17.05.2012
Сообщений: 2,687
27.10.2012, 13:17 #2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>  
 
static int summa = 0;
 
int rekurs(int n) 
{   
    if( n == 0) 
        return summa; 
    else  
    {
        summa += n % 10; 
        return rekurs( n/= 10);  
    }
    
}
 
int main() 
{ 
    int number = 12345; 
    
    std::cout << "Summa is " << rekurs(number) << std::endl;
}
1
Croessmah
Эксперт CЭксперт С++
13513 / 7671 / 866
Регистрация: 27.09.2012
Сообщений: 18,882
Записей в блоге: 3
Завершенные тесты: 1
27.10.2012, 13:17 #3
C++
1
2
3
int sumnum (int a)
{ return (a>0)?a%10+sumnum(a/10):0;
}
1
OhMyGodSoLong
~ Эврика! ~
1244 / 993 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
27.10.2012, 13:19 #4
Рекурсия 101.

Вот есть циклическая программа:
C++
1
2
3
4
5
6
7
8
9
int sumnum(int a)
{
    int d = 0;
    while (a > 0) {
        d += a % 10;
        a = a / 10;
    }
    return d; 
}
Цикл зависит только от двух локальных переменных: a и d. Выносим эти переменные в аргументы:
C++
1
2
3
4
int sumnum(int a, int d)
{
    ... sumnum(..., ...) ...
}
Рекурсивный вызов соответствует одной итерации цикла. Цикл заканчивается, когда a <= 0, и возвращает значение d:
C++
1
2
3
4
5
6
7
8
9
int sumnum(int a, int d)
{
    if (a > 0) {
        return sumnum(..., ...);
    }
    else {
        return d;
    }
}
На каждой итерации a делится на десять, а к d прибавляется остаток от деления a на десять:
C++
1
2
3
4
5
6
7
8
9
int sumnum(int a, int d)
{
    if (a > 0) {
        return sumnum(a / 10, d + a % 10);
    }
    else {
        return d;
    }
}
Осталось только установить начальное значение d:
C++
1
2
3
4
5
6
7
8
9
int sumnum(int a, int d = 0)
{
    if (a > 0) {
        return sumnum(a / 10, d + a % 10);
    }
    else {
        return d;
    }
}
1
David Sylva
27.10.2012, 13:52
  #5

Не по теме:

Parilo тебе ~OhMyGodSoLong~ всё здорово объяснил

0
Thinker
Эксперт С++
4227 / 2201 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
27.10.2012, 14:27 #6
Или лучше с одним параметром:
C++
1
2
3
4
unsigned int Sum(unsigned int a)
{
   return a ? a % 10 + Sum(a / 10) : 0;
}
Добавлено через 1 минуту
Цитата Сообщение от ~OhMyGodSoLong~ Посмотреть сообщение
Цикл зависит только от двух локальных переменных: a и d.
вернее сказать, что в цикле участвуют две переменные, а цикл зависит от значения одной переменной
0
27.10.2012, 14:27
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.10.2012, 14:27
Привет! Вот еще темы с ответами:

Написать рекурсивную функцию для нахождения произведения цифр натурального числа - C++
.Написать рекурсивную функцию для нахождения произведения цифр натурального числа. С помощью этой функции найти произведения цифр пяти...

написать программу которая вводит целое число и определяет сумму его цифр. Использовать функцию вычисления суммы цифр числа - C++
Помогите, Нужно написать программу которая вводит целое число и определяет сумму его цифр. Использовать функцию вычисления суммы цифр числа

Найти m! + (m+n)!, создав рекурсивную функцию для вычисления факториала произвольного натурального числа. C++ - C++
Вот программа с рекурсией напишите без рекурсии пожалуйста #include #include using namespace std; long long my_fact(long long n)...

Разработать рекурсивную функцию для вывода на экран цифр натурального числа в прямом порядке - C++
Разработать рекурсивную функцию для вывода на экран цифр натурального числа в прямом порядке. Применить эту функцию ко всем числам из...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru