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

Задана рекурсивная процедура: procedure PROC(n: integer);

begin

writeln(n);

if n < 10 then begin

PROC(n+4);

PROC(n*2)

end

end;

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

Ответ:
Vovndr
Vovndr
19.07.2022 06:06

63

Объяснение:

Алгоритм на естественном языке:

PROC(n) выводит n и, если n < 10, запускает PROC(n + 4) и PROC(2n).

Мысленно запустим PROC(3).

— PROC(3) выведет 3 и запустит PROC(6) и PROC(7)

— PROC(6) выведет 6 и запустит PROC(10) и PROC(12)

— PROC(7) выведет 7 и запустит PROC(11) и PROC(14)

— PROC(10), PROC(11), PROC(12) и PROC(14) выведут 10, 11, 12 и 14 соответственно и ничего больше запускать не будут.

Итого, будут выведены числа (не обязательно в этом порядке) 3, 6, 7, 10, 11, 12 и 14.

Сумма всех выведенных чисел 3 + 6 + 7 + 10 + 11 + 12 + 14 = 63

0,0(0 оценок)
Популярные вопросы: Информатика
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota Оформи подписку
logo
Начни делиться знаниями
Вход Регистрация
Что ты хочешь узнать?