()нужно откомментировать каждую строчку программы unit моисортировки; //библиотека interface procedure s_sort(var x: array of integer); procedure b_sort(var x: array of integer); procedure i_sort(var x: array of integer); implementation procedure s_sort(var x: array of integer); begin for var i:
= 0 to x.length -2 do begin//номер минимума var k: =i; //начальная позиция минимума for var j: = i + 1 to x.length - 1 do if x[j] < x[k] then k : = j; swap(x[i], x[k])//меняем местами значение на следующее end; end; procedure b_sort(var x: array of integer); begin for var i: = 0 to
x.length - 2 do begin//порядковый номер минимума var f: =true; //вводим переменную f for var j: = 1 to x.length - 1-i do//начальное значение минимума if x[j] < x[j-1] then begin//условие к новому значению(если они меньше начальное значение минимума begin var j: =i; //новое значение j var t: =x[i]; while (j< 0) and (t x[j]: =x[j-1]; j-=1; end; x[j]: =t end; end; end.
иначе не сможем выполнить 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.