Давай попробуем рассуждать логически. Если бы сад состоял из двух деревьев, то было бы два варианта садов: 100+99 и 100+101. Если бы досадили третье дерево, то каждый из предыдущих садов удвоил бы число вариантов: первый 100+99+98 и 100+99+100, и так же второй 100+101+100 и 100+101+102. Подмечаем закономерность: каждое добавляемое дерево удваивает количество вариантов. А сад из одного дерева имеет лишь один вариант.
Сначала надо избавиться от ошибок (пункт №3) иначе не сможем выполнить 1 и 2 пункт задания. Исправляем if N mod 10 k:=N mod 10; на if (N mod 10 < k) then k:=N mod 10; Исправляем N:N div 10; на N:= N div 10;
После исправления ошибок при вводе 537 получим 3 Программа будет работать правильно для любого числа, у которого вторая цифра слева меньше первой цифры, например: 7193
Чтобы программа работала правильно для всех чисел надо изменить это: while N > 10 do на while N > 0 do
После всех исправлений код программы стал таким: var N, k: integer; begin readln(N); k := 9; while N > 10 do begin if (N mod 10 < k) then k := N mod 10; N := N div 10; end; write(k) end.
В результате работы программы будет выведено 120
Объяснение:
Изначально переменной S присваивается значение 1. Затем, идёт цикл for k:=1 to 5
То есть, цикл выполнится столько раз, пока k не будет равно 5
Поясню заранее: итерация - повтор (чтобы было понятно, что за слова я пишу)
1) Первая итерация (k = 1)
s := s * 1 = 1 * 1 = 1
2) Вторая итерация (k = 2)
s := s *2 = 1 * 2 = 2
3) Третья итерация (k = 3)
s := s * 3 = 2 * 3 = 6
4) Четвертая итерация (k = 4)
s := s * 4 = 6 * 4 = 24
5) Последняя итерация (k = 5)
s := s * 5 = 24 * 5 = 120
Больше итераций не будет, т.к. мы дошли до того, что k = 5 (это же нам и требовалось)
В конце выведется последнее значение s, то есть, 120
Впрниципе, подробнее объяснения я придумать не смог
Надеюсь . Удачи!