16. Рекурсия

Рекурсивные алгоритмы в программировании (страница 4)

Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела 16. Рекурсия:

Это старая версия каталога задач

Нажмите для перехода на новую версию

Решаем задачи
Задание 22 #15204

Ниже на трёх языках программирования записан рекурсивный алгоритм F. \[\begin{array}{ | l | l | l |} \hline Python & C++ & Pascal \\ \hline def\; F(n): & void\; F(int\; n) & procedure\; F(n:\; integer); \\ \quad if\; n\; >\; 1: & \{ & \quad begin \\ \quad\quad print(n) & \quad if\; (n\; >\; 1) & \quad\quad if\; n\; >\; 1\; then \\ \quad\quad F(n\; -\; 1) & \quad \{ & \quad\quad\quad begin \\ \quad\quad print(n) & \quad\quad cout\; <<\; n; & \quad\quad\quad \; \; writeln(n); \\ & \quad\quad F(n\; -\; 1); & \quad\quad\quad \; \; \; F(n\; -\; 1); \\ & \quad\quad cout\; <<\; n; & \quad\quad\quad \; \; writeln(n); \\ & \quad \} & end \\ & \} & end \\ \hline \end{array}\]

Определите сумму цифр при вызове функции F(5)?

 

Показать решение

При вызове \(F(1)\) программа ничего не выведет. Пропишем весь алгоритм, начиная с \(F(2)\):
\( F(2)\rightarrow 2 F(1) 2 = 22\\ F(3)\rightarrow 3 F(2) 3= 3223\\ F(4)\rightarrow 4 F(3) 4= 432234\\ F(5)\rightarrow 5 F(4) 5 =54322345\\ \)

\(5+4+3+2+2+3+4+5=28\) И будет ответом на вопрос задачи.

Ответ: 28
Задание 23 #15203

Ниже на трёх языках программирования записан рекурсивный алгоритм F. \[\begin{array}{ | l | l | l |} \hline Python & C++ & Pascal \\ \hline def\; F(n): & void\; F(int\; n) & procedure\; F(n:\; integer); \\ \quad if\; n\; >\; 1: & \{ & \quad begin \\ \quad\quad print(n) & \quad if\; (n\; >\; 1) & \quad\quad if\; n\; >\; 1\; then \\ \quad\quad F(n\; -\; 1) & \quad \{ & \quad\quad\quad begin \\ \quad\quad F(n\; -\; 2) & \quad\quad cout\; <<\; n; & \quad\quad\quad \; \; writeln(n); \\ & \quad\quad F(n\; -\; 1); & \quad\quad\quad \; \; \; F(n\; -\; 1); \\ & \quad\quad F(n\; -\; 2); & \quad\quad\quad \; \; \; F(n\; -\; 2) \\ & \quad \} & end \\ & \} & end \\ \hline \end{array}\]

Определите сумму цифр при вызове функции F(5)?

 

Показать решение

При вызове \(F(0)\) и \(F(1)\) программа ничего не выведет. Пропишем весь алгоритм, начиная с \(F(2)\):
\( F(2)\rightarrow 2 F(1) F(0) = 2\\ F(3)\rightarrow 3 F(2) F(1)= 32\\ F(4)\rightarrow 4 F(3) F(2)= 4322\\ F(5)\rightarrow 5 F(4) F(3) = 5432232\\ \)

\(5+4+3+2+2+3+2=21\) И будет ответом на вопрос задачи.

Ответ: 21
Задание 24 #15202

Ниже на трёх языках программирования записан рекурсивный алгоритм F. \[\begin{array}{ | l | l | l |} \hline Python & C++ & Pascal \\ \hline def\; F(n): & void\; F(int\; n) & procedure\; F(n:\; integer); \\ \quad if\; n\; >\; 1: & \{ & \quad begin \\ \quad\quad F(n\; -\; 1) & \quad if\; (n\; >\; 1) & \quad\quad if\; n\; >\; 1\; then \\ \quad\quad print(n) & \quad \{ & \quad\quad\quad begin \\ \quad\quad F(n\; -\; 2) & \quad\quad F(n\; -\; 1); & \quad\quad\quad \; \; \; F(n\; -\; 1); \\ & \quad\quad cout\; <<\; n; & \quad\quad\quad \; \; writeln(n); \\ & \quad\quad F(n\; -\; 2); & \quad\quad\quad \; \; \; F(n\; -\; 2) \\ & \quad \} & end \\ & \} & end \\ \hline \end{array}\]

Определите, что выведет программа при вызове функции F(5)? Цифры запишите в той последовательности, в которой они выводятся.

 

Показать решение

При вызове \(F(0)\) и \(F(1)\) программа ничего не выведет. Пропишем весь алгоритм, начиная с \(F(2)\):
\( F(2)\rightarrow F(1) 2 F(0)= 2\\ F(3)\rightarrow F(2) 3 F(1)= 23\\ F(4)\rightarrow F(3) 4 F(2)= 2342\\ F(5)\rightarrow F(4) 5 F(3) = 2342523\\ \)

\(2342523\) И будет ответом на вопрос задачи.

Ответ: 2342523
Задание 25 #15201

Ниже на трёх языках программирования записан рекурсивный алгоритм F. \[\begin{array}{ | l | l | l |} \hline Python & C++ & Pascal \\ \hline def\; F(n): & void\; F(int\; n) & procedure\; F(n:\; integer); \\ \quad if\; n\; >\; 0: & \{ & \quad begin \\ \quad\quad F(n\; -\; 1) & \quad if\; (n\; >\; 0) & \quad\quad if\; n\; >\; 0\; then \\ \quad\quad F(n\; -\; 2) & \quad \{ & \quad\quad\quad begin \\ \quad\quad print(n) & \quad\quad F(n\; -\; 1); & \quad\quad\quad \; \; \; F(n\; -\; 1); \\ & \quad\quad F(n\; -\; 2); & \quad\quad\quad \; \; \; F(n\; -\; 2) \\ & \quad\quad cout\; <<\; n; & \quad\quad\quad \; \; writeln(n); \\ & \quad \} & end \\ & \} & end \\ \hline \end{array}\]

Определите, что выведет программа при вызове функции F(4)? Цифры запишите в той последовательности, в которой они выводятся.

 

Показать решение

При вызове \(F(0)\) и \(F(-1)\) программа ничего не выведет. Пропишем весь алгоритм, начиная с единицы:
\( F(1)\rightarrow F(0) F(-1) 1 = 1 \\ F(2)\rightarrow F(1) F(0) 2 = 12 \\ F(3)\rightarrow F(2) F(1) 3= 1213\\ F(4)\rightarrow F(3) F(2) 4= 1213124\\ \)

\(1213124\) И будет ответом на вопрос задачи.

Ответ: 1213124
Задание 26 #15200

Ниже на трёх языках программирования записан рекурсивный алгоритм F. \[\begin{array}{ | l | l | l |} \hline Python & C++ & Pascal \\ \hline def\; F(n): & void\; F(int\; n) & procedure\; F(n:\; integer); \\ \quad if\; n\; >\; 0: & \{ & \quad begin \\ \quad\quad F(n\; -\; 1) & \quad if\; (n\; >\; 0) & \quad\quad if\; n\; >\; 0\; then \\ \quad\quad F(n\; -\; 1) & \quad \{ & \quad\quad\quad begin \\ \quad\quad print(n) & \quad\quad F(n\; -\; 1); & \quad\quad\quad \; \; \; F(n\; -\; 1); \\ & \quad\quad F(n\; -1\; ); & \quad\quad\quad \; \; \; F(n\; -\; 1) \\ & \quad\quad cout\; <<\; n; & \quad\quad\quad \; \; writeln(n); \\ & \quad \} & end \\ & \} & end \\ \hline \end{array}\]

Определите, что выведет программа при вызове функции F(4)? Цифры запишите в той последовательности, в которой они выводятся.

 

Показать решение

При вызове \(F(0)\) программа ничего не выведет. Пропишем весь алгоритм, начиная с единицы:
\( F(1)\rightarrow F(0) F(0) 1 = 1 \\ F(2)\rightarrow F(1) F(1) 2 = 112 \\ F(3)\rightarrow F(2) F(2) 3= 1121123\\ F(4)\rightarrow F(3) F(3) 4= 112112311211234\\ \)

\(112112311211234\) И будет ответом на вопрос задачи.

Ответ: 112112311211234
Задание 27 #15199

Ниже на трёх языках программирования записан рекурсивный алгоритм F.

\[\begin{array}{ | l | l | l |} \hline Python & C++ & Pascal \\ \hline def\; F(n): & void\; F(int\; n) & procedure\; F(n:\; integer); \\ \quad if\; n\; >\; 0: & \{ & \quad begin \\ \quad\quad F(n\; -\; 1) & \quad if\; (n\; >\; 0) & \quad\quad if\; n\; >\; 0\; then \\ \quad\quad print(n) & \quad \{ & \quad\quad\quad begin \\ \quad\quad F(n\; -\; 1) & \quad\quad F(n\; -\; 1); & \quad\quad\quad \; \; \; F(n\; -\; 1); \\ & \quad\quad cout\; <<\; n; & \quad\quad\quad \; \; \; writeln(n); \\ & \quad\quad F(n\; -1\; ); & \quad\quad\quad \; \; \; F(n\; -\; 1) \\ & \quad \} & \quad\quad\quad end; \\ & \} & \quad end; \\ \hline \end{array}\]

Определите сумму цифр при вызове функции F(4)?

 

Показать решение

При вызове \(F(0)\) программа ничего не выведет. Пропишем весь алгоритм, начиная с единицы:

 

\( F(1)\rightarrow F(0) 1 F(0) = 1 \\ F(2)\rightarrow F(1) 2 F(1) = 121 \\ F(3)\rightarrow F(2) 3 F(2) = 1213121\\ F(4)\rightarrow F(3) 4 F(3) = 121312141213121\\ \)

\(4+3+2+1+1+2+1+1+3+2+1+1+2+1+1=26\) И будет ответом на вопрос задачи.

Ответ: 26
Задание 28 #15198

Ниже на трёх языках программирования записан рекурсивный алгоритм F. \[\begin{array}{ | l | l | l |} \hline Python & C++ & Pascal \\ \hline def\; F(n): & void\; F(int\; n) & procedure\; F(n:\; integer); \\ \quad if\; n\; >\; 0: & \{ & \quad begin \\ \quad\quad print(n) & \quad if\; (n\; >\; 0) & \quad\quad if\; n\; >\; 0\; then \\ \quad\quad F(n\; -\; 1) & \quad \{ & \quad\quad\quad begin \\ \quad\quad F(n\; -\; 1) & \quad\quad cout\; <<\; n; & \quad\quad\quad \; \; \; writeln(n); \\ & \quad\quad F(n\; -\; 1); & \quad\quad\quad \; \; \; F(n\; -\; 1); \\ & \quad\quad F(n\; -1\; ); & \quad\quad\quad \; \; \; F(n\; -\; 1) \\ & \quad \} & \quad\quad\quad end; \\ & \} & \quad end; \\ \hline \end{array}\]

Определите, что выведет программа при вызове функции F(4)? Цифры запишите в той последовательности, в которой они выводятся.

 

Показать решение

При вызове \(F(0)\) программа ничего не выведет. Пропишем весь алгоритм, начиная с единицы:

 

\( F(1)\rightarrow 1 F(0) F(0) = 1 \\ F(2)\rightarrow 2 F(1) F(1) = 211 \\ F(3)\rightarrow 3 F(2) F(2) = 3211211\\ F(4)\rightarrow 4 F(3) F(3) = 432112113211211 \\ \)

\(432112113211211\) И будет ответом на вопрос задачи.

Ответ: 432112113211211
1

...

3

4

5

...

7
Рулетка
Вы можете получить скидку в рулетке!