Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.66/47: Рейтинг темы: голосов - 47, средняя оценка - 4.66
4 / 4 / 5
Регистрация: 13.10.2016
Сообщений: 116

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

14.12.2016, 01:01. Показов 10164. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Разработать рекурсивную функцию, возвращающую значение для вычисления количества цифр в заданном натуральном числе.

Обращаюсь в который раз к вашему теплому костру за помощью так, как на парах "мы такого не проходили" и не объясняют, а в теории методички ничего подобного нет.
Прошу, сделайте пожалуйста в легкой форме.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.12.2016, 01:01
Ответы с готовыми решениями:

Вычислить количество цифр в заданном натуральном числе
Вычисление количества цифр в заданном натуральном числе. Максимально вычисляет 10, что мне делать? #include <iostream> ...

Подсчитать количество цифр в заданном натуральном числе.
Подсчитать количество цифр в заданном натуральном числе. (как можно понятнее и проще, если можно)

Найти количество цифр в заданном натуральном числе
найти сколько цифр в данном натуральном числе n(n<=100) c++ Очень надо.

9
21 / 21 / 8
Регистрация: 07.08.2015
Сообщений: 48
14.12.2016, 02:30
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
 
using std::cout;
using std::endl;
 
typedef long long int big_int;
 
big_int get_count(big_int);
 
int main(int argc, char *argv[])
{
    cout << get_count(123) << endl;
 
    return 0;
}
 
big_int get_count(big_int number)
{
    return number / 10 ? get_count(number / 10) + 1 : 1;
}
1
4 / 4 / 5
Регистрация: 13.10.2016
Сообщений: 116
14.12.2016, 02:39  [ТС]
Можно, пожалуйста, в упрощенном стиле? Или проверьте, где у меня ошибка.
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
#include <iostream>
using namespace std;
 
void func(int n, int &k)
{
    k = 0;
    while (n > 0)
    {
        n = n % 10;
        k += 1;
    }
    return;
}
 
int main()
{
    int n, k;
    cout << "n="; cin >> n;
    cout << "k=";
    func(n, k); 
    cout << k << endl;
    system("pause");
    return 0;
}
0
21 / 21 / 8
Регистрация: 07.08.2015
Сообщений: 48
14.12.2016, 02:50
vladrrom, у вас не рекурсивная функция. Рекурсивной называется такая функция, которая вызывает саму себя.

Добавлено через 2 минуты
vladrrom, а ошибка в строке 9
C++
1
n = n % 10;
замените на
C++
1
n = n / 10;
Деление по модулю не даст вам отрицательного результата и условие будет бесконечным.
1
4 / 4 / 5
Регистрация: 13.10.2016
Сообщений: 116
14.12.2016, 02:54  [ТС]
Просветите меня, как сделать рекурсивную ф-цию xD
Пожалуйста.
0
21 / 21 / 8
Регистрация: 07.08.2015
Сообщений: 48
14.12.2016, 03:08
vladrrom,

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
 
using std::cout;
using std::endl;
 
typedef long long int big_int;
 
big_int get_count(big_int);
 
int main(int argc, char *argv[])
{
    cout << get_count(123) << endl;
 
    return 0;
}
 
big_int get_count(big_int number)
{
    return number / 10 ? get_count(number / 10) + 1 : 1;
}
В коде выше, get_count() - рекурсивная функция, так как вызывает саму себя при вычислениях. Все просто:

? - это тернарный оператор, слева от него условие, справа два возможных варианта - что_делать_если_true : что_делать_если_false. Он действует подобно if-else, только в одну строку.

typedef в начале можно и исключить, сделать просто на int, этот оператор создает псевдоним для типа. Т.е long long int теперь можно писать кратко - big_int

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

Добавлено через 7 минут
vladrrom, вот например, возьмем значение 123 и вызовем функцию:

1. Сначала в условии 123 делится на 10, что дает результат 12,3, но так как это тип int, то дробная часть отпадает.
2. Проверяется условие. Так как в C++ все что не 0 - это true, то и 12 даст true.
3. Вызывается true блок тернарного оператора (?)
4. В true-блоке вызывается эта же функция с новым значением 12
5. Снова вычисления, опять проверка условия, отбрасывание дробной части - результат 1, true. Вызываем true блок
6. Вычисления, куда же без них. Проверка условия, отбрасывание дробной части - результат 0, false. Вызывается false блок

7. Вот тут самое интересное, рекурсивная функция начинает развязываться и возвращает значение 1
8. В функции, которая вызывалась со значением 12 вернулся результат 1, к нему прибавляется единица и возвращается значение 2
9. В функции, которая вызывалась со значением 123 вернулся результат 2, к нему прибавляется единица и возвращается значение 3

Итого: в числе 3 цифры.

Может, сначала это и покажется сложным, но все гораздо проще
1
4 / 4 / 5
Регистрация: 13.10.2016
Сообщений: 116
14.12.2016, 03:20  [ТС]
Суть рекурсивной ф-ции я вроде понял. Но не пойму как код написать. Так, как вы предложили мы не проходили.. возможно так более шаренным кодерам, как вы и понятно, но студентам только 1-го курса, пока нет))
Следует вопрос: как объявить ф-цию? Таким образом:
void get_count(big_int, number)
{
.. //также как записать условие с if-ом? Я думал if (get_count(number / 10) + 1) {number = number / 10;} else return 1;
}
И ещё 1 момент:
Цитата Сообщение от Grank Посмотреть сообщение
cout << get_count(123) << endl;
Почему мы запрашиваем ф-цию, а не вводим число.
P.S. ночью кателок худо работает, извиняюсь за лаги xD
0
21 / 21 / 8
Регистрация: 07.08.2015
Сообщений: 48
14.12.2016, 03:28
Лучший ответ Сообщение было отмечено vladrrom как решение

Решение

vladrrom, это просто пример, можно модифицировать
C++
1
2
3
4
int number = 0;
 
cin >> number;
cout << get_count(number) << endl;
Насколько я понял, функция должна возвращать натуральное число, которое обозначает количество цифр. void - это пустота, функция не будет возвращать значения. На if-else можно написать так:

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
#include <iostream>
 
using std::cout;
using std::endl;
using std::cin;
 
int get_count(int);
 
int main(int argc, char *argv[])
{
    int number = 0;
 
    cin >> number;
    cout << get_count(number) << endl;
 
    return 0;
}
 
int get_count(int number)
{
    if (number / 10)
        return get_count(number / 10) + 1;
    else
        return 1;
}
1
4 / 4 / 5
Регистрация: 13.10.2016
Сообщений: 116
14.12.2016, 03:46  [ТС]
Просто лучший! Большое спасибо! Я разобрался теперь уж точно с рекурсивной функцией раз и навсегда!
Не каждый способен помочь в 5 часу утра помогать студенту с хвостами xD, но Вы превзошли всех и очень мне помогли.
Благодарю Вас.
0
0 / 0 / 0
Регистрация: 18.05.2018
Сообщений: 4
18.05.2018, 10:27
Grank, здравствуйте не могли бы помоч Разработать рекурсивный алгоритм, написать реализующую его рекурсивную подпрограмму на С++ и проверить на тестовых данных.
Вычислить значение логического выражения, заданного с клавиатуры, состоящего из натуральных чисел, скобок и операций „&‟ (поразрядное логическое „и‟) и „~‟ (поразрядное логическое „не‟). Например, ~8 & (64 & 125) будет равно 11110111 & 1000000 = 64. Операции „&‟ и „~‟ предполагаются имеющими одинаковый приоритет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.05.2018, 10:27
Помогаю со студенческими работами здесь

Определить количество цифр 3 в заданном натуральном числе
Дано натуральное число, определить а) количество цифр 3 в нем;

Рекурсия: подсчитать количество цифр в заданном натуральном числе
Доброго времени суток. Задание было такое: Тема - Рекурсивные функции пользователя. Подсчитать количество цифр в заданном натуральном...

Подсчитать количество цифр k в заданном натуральном числе, где k – случайная цифра
Дано натуральное число n. Подсчитать количество цифр k в числе, где k – случайное число.(л3,з2)

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

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


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru