Сначала надо избавиться от ошибок (пункт №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.
Задание невозможно решить!! Буква а может быть закодирована как 010, так и 0. Рассмотрим оба случая: 1) А-010, Р-01, К-00 Тогда, когда мы начнем расшифровывать последовательность получится, что первая буква К, а дальнейшая расшифровка невозможна. 2) А - 0, Р-1001, К-0001 Тогда, когда мы начнем расшифровывать заданную последовательность получится, что первые две буквы АА, а дальнейшая расшифровка невозможна.
Единственное более или менее адекватное решение : А-0, Р-100, К-10001 Тогда расшифровка - ААК. Но, во-первых, такого ответа нет в вариантах, а, во-вторых, тогда и шифровка согласных букв имеет разную длину. Думайте сами, решайте сами.. Возможно, Вы опечатались?
0,0(0 оценок)
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota
Оформи подписку