В
Все
У
Українська література
Г
Геометрия
Д
Другие предметы
Э
Экономика
Г
География
О
ОБЖ
М
Математика
М
МХК
Х
Химия
Қ
Қазақ тiлi
Л
Литература
У
Українська мова
О
Обществознание
Ф
Физика
А
Английский язык
А
Алгебра
И
История
Б
Беларуская мова
Б
Биология
М
Музыка
П
Право
И
Информатика
П
Психология
В
Видео-ответы
Н
Немецкий язык
Ф
Французский язык
О
Окружающий мир
Р
Русский язык
Marymol2005
Marymol2005
29.07.2021 18:52 •  Информатика

Предоставлен рекурсивный алгоритм: procedure F(n: integer);
begin
writeln(n);
if n < 5 then
begin
F(n + 3);
F(n * 3)
end
end;
Определите и напишите сумму чисел, которые будут выведены при вызове F(1).

Ответ:
Шkolnitsa
Шkolnitsa
26.12.2020 15:50

42

Объяснение:

F(1): вывод 1. Т.к. 1<5, произойдут рекурсивные вызовы

       F(1+3)=F(4): вывод 4. Т.к. 4<5, произойдут рекурсивные вызовы

               F(4+3)=F(7): вывод 7. Т.к. 7>5, рекурсивные вызовы не произойдут.

               F(4*3)=F(12): вывод 12. Т.к. 12>5, рекурсивные вызовы не произойдут.

       F(1*3)=F(3): вывод 3. Т.к. 3<5, произойдут рекурсивные вызовы

               F(3+3)=F(6): вывод 6. Т.к. 6>5, рекурсивные вызовы не произойдут.

               F(3*3)=F(9): вывод 9. Т.к. 9>5, рекурсивные вызовы не произойдут.

Сумма выведенных чисел будет равна 1+4+7+12+3+6+9=42


Предоставлен рекурсивный алгоритм: procedure F(n: integer); begin writeln(n); if n < 5 then begi
0,0(0 оценок)
Популярные вопросы: Информатика
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota Оформи подписку
logo
Начни делиться знаниями
Вход Регистрация
Что ты хочешь узнать?