выучи три команды из СКИ (системы команд исполнителя) "Стрелочка". Это будет быстрее чем задавать вопросы в И-нет: ШАГ -перемещение на одно деление с рисованием линии; ПРЫЖОК -перемещение на одно деление без рисования линии; ПОВОРОТ -изменение направления движения на 90 гр. против часовой стрелки. А пока держи алгоритмы (исходные данные то же, что и в предыдущих примерах:
Сначала надо избавиться от ошибок (пункт №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.
ШАГ -перемещение на одно деление с рисованием линии;
ПРЫЖОК -перемещение на одно деление без рисования линии;
ПОВОРОТ -изменение направления движения на 90 гр. против часовой стрелки.
А пока держи алгоритмы (исходные данные то же, что и в предыдущих примерах:
Буква Ш:
АЛГОРИТМ ПУТЬ_0 Дано: Исполнитель в т.А Надо: Воспроизвести образецНАЧ ПОВОРОТ ПОВОРОТ ПОВОРОТ ШАГ ШАГ ПОВОРОТ ШАГ ШАГ ПОВОРОТ ШАГ ШАГ ПОВОРОТ ПРЫЖОК ПОВОРОТ ШАГ ШАГКОН
Буква Ц
АЛГОРИТМ ПУТЬ_0 Дано: Исполнитель в т.А Надо: Воспроизвести образецНАЧ ПОВОРОТ ПОВОРОТ ПОВОРОТ ШАГ ШАГ ШАГ ПОВОРОТ ШАГ ШАГ ПОВОРОТ ШАГ ШАГ ШАГ ПОВОРОТ ПОВОРОТ ПРЫЖОК ПРЫЖОК ПРЫЖОК ПОВОРОТ ШАГ ПОВОРОТ ПОВОРОТ ПОВОРОТ ШАГКОН
Буква Ч
АЛГОРИТМ ПУТЬ_0 Дано: Исполнитель в т.А Надо: Воспроизвести образецНАЧ ПОВОРОТ ПОВОРОТ ПОВОРОТ ШАГ ПОВОРОТ ШАГ ПОВОРОТ ШАГ ПОВОРОТ ПОВОРОТ ПРЫЖОК ШАГКОН
Буква Б
АЛГОРИТМ ПУТЬ_0 Дано: Исполнитель в т.А Надо: Воспроизвести образецНАЧ ПРЫЖОК ПОВОРОТ ПОВОРОТ ШАГ ПОВОРОТ ШАГ ШАГ ПОВОРОТ ШАГ ПОВОРОТ ШАГ ПОВОРОТ ШАГКОН
Буква П
АЛГОРИТМ ПУТЬ_0 Дано: Исполнитель в т.А Надо: Воспроизвести образецНАЧ ШАГ ПОВОРОТ ПОВОРОТ ПОВОРОТ ШАГ ШАГ ПОВОРОТ ПОВОРОТ ПОВОРОТ ПРЫЖОК ПОВОРОТ ПОВОРОТ ПОВОРОТ ШАГ ШАГКОН
Буква Е
АЛГОРИТМ ПУТЬ_0 Дано: Исполнитель в т.А Надо: Воспроизвести образецНАЧ ШАГ ПОВОРОТ ПОВОРОТ ПРЫЖОК ПОВОРОТ ШАГ ШАГ ПОВОРОТ ШАГ ПОВОРОТ ПРЫЖОК ПОВОРОТ ШАГКОН
иначе не сможем выполнить 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.