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

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

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

Author24 — интернет-сервис помощи студентам
Дан рекурсивный алгоритм:
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
Модератор
Эксперт по электронике
8962 / 6728 / 921
Регистрация: 14.02.2011
Сообщений: 23,751
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
Модератор
Эксперт по электронике
8962 / 6728 / 921
Регистрация: 14.02.2011
Сообщений: 23,751
22.01.2015, 19:36
romkds,
я про другое спрашивал
вот ты выводишь n до вызова функции и после, как думаешь разные значения будет оно иметь?
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
37907 / 20973 / 4295
Регистрация: 12.02.2012
Сообщений: 34,510
Записей в блоге: 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
Модератор
Эксперт по электронике
8962 / 6728 / 921
Регистрация: 14.02.2011
Сообщений: 23,751
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
Модератор
Эксперт по электронике
8962 / 6728 / 921
Регистрация: 14.02.2011
Сообщений: 23,751
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Создаем RESTful API с Laravel
Jason-Webb 28.04.2025
REST (Representational State Transfer) — это архитектурный стиль, который определяет набор принципов для создания веб-сервисов. Этот подход к построению API стал стандартом де-факто в современной. . .
Дженерики в C# - продвинутые техники
stackOverflow 28.04.2025
История дженериков началась с простой идеи — создать механизм для разработки типобезопасного кода без потери производительности. До их появления программисты использовали неуклюжие преобразования. . .
Тестирование в Python: PyTest, Mock и лучшие практики TDD
py-thonny 28.04.2025
Тестирование кода играет весомую роль в жизненном цикле разработки программного обеспечения. Для разработчиков Python существует богатый выбор инструментов, позволяющих создавать надёжные и. . .
Работа с PDF в Java с iText
Javaican 28.04.2025
Среди всех форматов PDF (Portable Document Format) заслуженно занимает особое место. Этот формат, созданный компанией Adobe, превратился в универсальный стандарт для обмена документами, не зависящий. . .
Динамические массивы в C++ - создание и использование
NullReferenced 27.04.2025
Динамические массивы представляют собой один из фундаментальных инструментов программирования на C++, позволяющий создавать структуры данных, размер которых определяется во время выполнения. . .
Асинхронный JavaScript: Промисы, Async/Await и Fetch API
Reangularity 27.04.2025
Пользователь заходит на веб-страницу, нажимает кнопку и. . . ничего не происходит. Сайт словно замер. Через несколько секунд всё внезапно оживает, но пользователь уже успел закрыть вкладку. Знакомая. . .
Management on GitLab and repository management in Visual Studio code
jigi33 27.04.2025
- repo management on GitLab - CI/ CD in GitLab - VCS repository management in Visual Studio code (see attachments)
Kanban или Scrum - что выбрать?
EggHead 27.04.2025
Kanban и Scrum — уже много лет удерживают лидирующие позиции среди гибких подходов. Руководители проектов и команды разработчиков то и дело сталкиваются с дилеммой: какой из этих двух методов выбрать. . .
Кастомные Middleware на C# в ASP.NET Core
UnmanagedCoder 27.04.2025
Разработка веб-приложений сегодня мало напоминает монолитное программирование прошлых лет. На смену громоздким блокам кода пришла модульная архитектура, где каждый компонент выполняет строго. . .
Анализ и линтинг кода JavaScript: ESLint, Prettier и JSHint
run.dev 26.04.2025
JavaScript прошёл долгий путь от простого языка для анимации веб-страниц до основы современной веб-разработки. С ростом сложности приложений, увеличением кодовых баз и масштабированием команд. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru