Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
60 / 45 / 12
Регистрация: 07.10.2011
Сообщений: 139
1

Задача на рекурсию

07.11.2012, 18:55. Просмотров 970. Ответов 6
Метки нет (Все метки)

Дано число. Вывести все цифры этого числа, не используя дополнительных библиотек, массивов, списков и т.д. Использовать только рекурсию.Пример ввода : 123. Вывод: 1 2 3. Число ограничивается INT_MAX.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
07.11.2012, 18:55
Ответы с готовыми решениями:

Задача на рекурсию
Задание: написать функцию умножения двух чисел, используя только операции сложения и рекурсии. Не...

Задача на рекурсию
помогите написать пожалуйста программу на с++ по теме рекурсия. Задано действительное A, найти...

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

Задача на рекурсию
Всем доброго времени суток. Прошу подсказать мне условие задачи на рекурсию(нам дали задание самим...

6
6209 / 3510 / 899
Регистрация: 28.10.2010
Сообщений: 5,926
07.11.2012, 18:58 2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
 
void func(int num)
{
    if (!num)
        return;
    else
    {
        std::cout << (num % 10) << ' ';
        func(num / 10);
    }
}
 
int main()
{
    int num;
    std::cin >> num;
    func(num);
}
1
60 / 45 / 12
Регистрация: 07.10.2011
Сообщений: 139
07.11.2012, 19:00  [ТС] 3
Вывод не правильный
0
6209 / 3510 / 899
Регистрация: 28.10.2010
Сообщений: 5,926
07.11.2012, 19:01 4
yleart, в задании не сказано, в каком порядке должны идти цифры.
1
60 / 45 / 12
Регистрация: 07.10.2011
Сообщений: 139
07.11.2012, 19:02  [ТС] 5
Не дописал задание, простите. Вывод слева направо
0
6209 / 3510 / 899
Регистрация: 28.10.2010
Сообщений: 5,926
07.11.2012, 19:03 6
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
#include <iostream>
 
int reverse(int num)
{
    int res = 0;
    while (num)
    {
        res = (res + num % 10) * 10;
        num /= 10;
    }
    return res / 10;
}
 
void func(int num)
{
    if (!num)
        return;
    else
    {
        std::cout << (num % 10) << ' ';
        func(num / 10);
    }
}
 
int main()
{
    int num;
    std::cin >> num;
    func(reverse(num));
}
1
1306 / 968 / 267
Регистрация: 17.05.2012
Сообщений: 2,687
07.11.2012, 19:05 7
Лучший ответ Сообщение было отмечено как решение

Решение

Такой вариант
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream> 
 
void show(int n) 
{ 
    if(n) 
    { 
        show( n / 10); 
        std::cout <<  n % 10 << " "; 
    }
}
 
 
int main() 
{ 
    int n = 123; 
    show(n); 
}
3
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
07.11.2012, 19:05

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Задача на рекурсию
Вот код проги которую я написал: #include &lt;iostream&gt; using namespace std; int factr(double...

Задача на рекурсию
Дано натуральное число n. Выяснить, имеется ли среди чисел n, n+1, ..., 2n близнецы, т.е. простые...

Задача на рекурсию
С помощью рекурсии вычислить произведение ненулевых элементов динамического массива. Кто-то знает?...

Задача на рекурсию
Помогите решить след. задачу: Вот мой вариант, но здесь не сохраняется порядок: void Func()...


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

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

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