Система команд исполнителя робот, “живущего” в прямоугольном лабиринте на клетчатой плоскости:
вверх
вниз
влево
вправо
при выполнении этих команд робот перемещается на одну клетку соответственно: вверх ↑, вниз ↓, влево ←, вправо →.
четыре команды проверяют истинность условия отсутствия стены у той клетки, где находится робот:
сверху свободно
снизу свободно
слева свободно
справа свободно
цикл
пока команда
выполняется, пока условие истинно, иначе происходит переход на следующую строку.
при движении в сторону стены робот разрушается, и выполнение программы прерывается.
сколько клеток лабиринта соответствует требованию, что, выполнив предложенную ниже программу, робот остановится в той же клетке, с которой он начал движение?
начало
пока вверх
пока влево
пока вниз
пока вправо
конец
варианты ответа
1) 1
2) 2
3) 3
4) 4
var
a, s: real; //a - вводимое с клавиатуры число, s - сумма чисел
begin
a:= 1; //Присваиваем начальное значение, чтобы цикл выполнился
s:= 0;
while a <> 0 do
begin
writeln('Введите положительное число');
readln(a);
if a < 0 then
begin
writeln('Введено не положительное число. Повторите ввод заново');
continue; {Если а - не положительное число, вводим число заново}
end;
s:= s + a;
end;
writeln('Сумма: ', s); //Выводим сумму
end.
program exs;
var a : array [1..1000] of integer;
n, i : integer;
procedure qsort(l, r: integer);
var i, j, key, buf : integer;
begin
i := l;
j:= r;
key:=a[(l+r) div 2];
repeat
while a[i] < key do inc(i);
while a[j] > key do dec(j);
if i<=j then begin
buf:=a[i];
a[i]:=a[j];
a[j]:=buf;
inc(i);
dec(j);
end;
until (i>j);
if (l < j) then qsort(l, j);
if (i < r) then qsort(i, r);
end;
begin
readln(n);
for i:= 1 to n do begin
read(a[i]);
end;
qsort(1, n);
for i:=1 to n do begin
write(a[i], ' ');
end;
end.