0 / 0 / 0
Регистрация: 13.09.2014
Сообщений: 18

Дан рекурсивный алгоритм. Найдите сумму чисел, которые будут выведены при вызове F(2)

22.01.2015, 18:40. Показов 8262. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан рекурсивный алгоритм:
C++
1
2
3
4
5
6
7
8
9
10
11
void F(int n)
{
 cout << n;
 if (n < 7)
 {
   cout << n;
   F(n+1);
   F(n+2);
   F(n*3);
 }
}
Найдите сумму чисел, которые будут выведены при вызове F(2)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.01.2015, 18:40
Ответы с готовыми решениями:

Найдите сумму чисел,которые будут выведены при вызове F(2)
дан рекурсивный алгоритм procedure F(n:integer)l begin writeln(n); if n&lt;7 then begin F(n+3); F(n*2) end end; Найдите...

Определите наименьшее значение n, при котором сумма чисел, которые будут выведены при вызове F(n), будет больше 1000000
Определите наименьшее значение n, при котором сумма чисел, которые будут выведены при вызове F(n), будет больше 1000000 Запишите в ответе...

Найдите сумму чисел от 1 до n, которые кратны 17 и 19
Hello, world!) Задание: Найдите сумму чисел от 1 до n, которые кратны 17 и 19 def mult(n) i, sum = 1, 0 while i &lt;= n ...

10
1 / 1 / 1
Регистрация: 20.01.2015
Сообщений: 22
22.01.2015, 18:57
Можно вывести сумму после каждого вызова функции
Например:
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 <cstdlib>
#include <iostream>
using namespace std;
void F(int n)
{
cout << n << endl;
if (n < 7)
{
F(n+1);
cout << n << endl;
F(n+2);
cout << n << endl;
F(n*3);
cout << n << endl;
}
}
 
int main (int argc, char **argv)
{
F(2);
   system("PAUSE");
   return EXIT_SUCCESS;
}
Добавлено через 1 минуту
Если же после вызова последней функции то можно cout после строчки 13 только оставить F(n*3);
1
Модератор
Эксперт по электронике
8981 / 6748 / 921
Регистрация: 14.02.2011
Сообщений: 23,871
22.01.2015, 19:08
Цитата Сообщение от romkds Посмотреть сообщение
Например:
Цитата Сообщение от romkds Посмотреть сообщение
cout << n << endl;
F(n+2);
cout << n << endl;
а думаешь n изменится?
0
1 / 1 / 1
Регистрация: 20.01.2015
Сообщений: 22
22.01.2015, 19:25
C++
1
if (n < 7)
при этом условии функция не выполняется если цифра при постепенном увеличении становится больше 6
0
Модератор
Эксперт по электронике
8981 / 6748 / 921
Регистрация: 14.02.2011
Сообщений: 23,871
22.01.2015, 19:36
romkds,
я про другое спрашивал
вот ты выводишь n до вызова функции и после, как думаешь разные значения будет оно иметь?
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38180 / 21115 / 4307
Регистрация: 12.02.2012
Сообщений: 34,722
Записей в блоге: 14
22.01.2015, 19:38
У меня получилось:

2
3
4
5
6
6
5
6
4
5
6
6
6

Сумма=64
0
1 / 1 / 1
Регистрация: 20.01.2015
Сообщений: 22
22.01.2015, 19:42
Цитата Сообщение от ValeryS Посмотреть сообщение
вот ты выводишь n до вызова функции и после, как думаешь разные значения будет оно иметь?
У меня при запуске разные значения выводит)
0
Модератор
Эксперт по электронике
8981 / 6748 / 921
Регистрация: 14.02.2011
Сообщений: 23,871
22.01.2015, 19:52
Цитата Сообщение от romkds Посмотреть сообщение
У меня при запуске разные значения выводит)
разные потому, что в рекурсию попадаешь и значения из разной глубины выводятся
попробуй введи F(6)
чтобы работать в одном вложении и увидишь что 6 будут появляться

Добавлено через 4 минуты
а чтобы было понятно переделаю немножко твою функцию
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
void F(int n, int attach)
{
attach++;
cout << n << "attachments"<<attach<<endl;
if (n < 7)
{
F(n+1,attach);
cout << n << "attachments"<<attach<<endl;
F(n+2,attach);
cout << n << "attachments"<<attach<<endl;
F(n*3,attach);
cout << n << "attachments"<<attach<<endl;
}
}
 
int main (int argc, char **argv)
{
F(2,0);
   system("PAUSE");
   return EXIT_SUCCESS;
}
посмотри цифры при одном уровне вложений
0
1 / 1 / 1
Регистрация: 20.01.2015
Сообщений: 22
22.01.2015, 20:07
Внес код вот что получилось
2attachments1
3attachments2
4attachments3
5attachments4
6attachments5
7attachments6
6attachments5
8attachments6
6attachments5
18attachments6
6attachments5
5attachments4
7attachments5
5attachments4
15attachments5
5attachments4
4attachments3
6attachments4
7attachments5
6attachments4
8attachments5
6attachments4
18attachments5
6attachments4
4attachments3
12attachments4
4attachments3
3attachments2
5attachments3
6attachments4
7attachments5
6attachments4
8attachments5
6attachments4
18attachments5
6attachments4
5attachments3
7attachments4
5attachments3
15attachments4
5attachments3
3attachments2
9attachments3
3attachments2
2attachments1
4attachments2
5attachments3
6attachments4
7attachments5
6attachments4
8attachments5
6attachments4
18attachments5
6attachments4
5attachments3
7attachments4
5attachments3
15attachments4
5attachments3
4attachments2
6attachments3
7attachments4
6attachments3
8attachments4
6attachments3
18attachments4
6attachments3
4attachments2
12attachments3
4attachments2
2attachments1
6attachments2
7attachments3
6attachments2
8attachments3
6attachments2
18attachments3
6attachments2
2attachments1
0
Модератор
Эксперт по электронике
8981 / 6748 / 921
Регистрация: 14.02.2011
Сообщений: 23,871
22.01.2015, 20:17
Цитата Сообщение от romkds Посмотреть сообщение
Внес код вот что получилось
а теперь смотри одно вложение например 1
Цитата Сообщение от romkds Посмотреть сообщение
2attachments1

.................
2attachments1
.....................
2attachments1
......................
2attachments1
как видишь n нигде не меняется
сколько в функцию передали столько и выводим
Рекурсивные функции достаточно сложны для понятия,лучше всего
вручную пройти, в тетрадке, причем каждый заход на новой странице и по шагам
это не цикл, здесь другое видение нужно
1
1 / 1 / 1
Регистрация: 20.01.2015
Сообщений: 22
22.01.2015, 20:30
Действительно есть повторения. Надо еще позаниматься, а то в основном только факториал наиболее часто встречается. Спасибо за информацию!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.01.2015, 20:30
Помогаю со студенческими работами здесь

Для двух целых чисел a и b, которые могут быть положительными или отрицательными, найдите сумму всех чисел между их вклю
Для двух целых чисел a и b, которые могут быть положительными или отрицательными, найдите сумму всех чисел между их включением и...

Найдите сумму нечетных чисел массива, которые не превосходят 11
Найдите сумму нечетных чисел массива, которые не превосходят 11 python 3,7

Найдите сумму нечётных чисел массива, которые не превосходят 11
Дан массив размером N. Найдите сумму нечётных чисел массива, которые не превосходят 11. Язык программирования Паскаль. Нужна блок-схема и...

Найдите сумму чисел массива, которые стоят на четных местах
Найдите сумму чисел массива, которые стоят на четных местах python 3.7

Дан массив целых чисел. найдите сумму положительных элементов,значения которых меньше 10
Дан массив целых чисел. найдите сумму положительных элементов,значения которых меньше 10


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

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

Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru