Олимпиада по информатике 8 класс, 10 задание. Какой рисунок нарисует челтёжник после выполнения алгоритма?
Использовать чертёжник
алг квадрат
нач
иц 2 раз
ПРОЦЕД_КВАДРАТ
сместиться на вектор (2,2)
ПРОЦЕД_квадрат
сместиться на вектор (1,1)
кц
кон
алг ПРОЦЕД_КВАДРАТ
нач
опуситить перо
сместиться на вектор (0, 2)
сместиться на вектор (2, 0)
сместиться на вектор (0, -2)
сместиться на вектор (-2, 0)
поднять перо
кон
алг ПРОЦЕД_квадрат
нач
Опустить перо
сместиться на вектор (0, 1)
сместиться на вектор (1, 0)
сместиться на вектор (0, -1)
сместиться на вектор (-1, 0)
поднять перо
кон
// PascalABC.NET 3.2, сборка 1417 от 28.03.2017
// Внимание! Если программа не работает, обновите версию!
type
Pinnacle=record
St:Stack<integer>;
No:integer;
constructor (n:integer);
begin
St:=new Stack<integer>;
No:=n
end;
end;
var
MoveNo:integer;
procedure MoveDisk(s1,s2:Pinnacle);
begin
if s1.St.Count>0 then begin
MoveNo+=1;
s2.St.Push(s1.St.Pop);
Writeln(MoveNo:3,': №',s2.St.Peek,' ',s1.No,' -> ',s2.No)
end
end;
procedure MovePinnacle(n:integer; s1,s2,s3:Pinnacle);
begin
if n=0 then exit;
MovePinnacle(n-1,s1,s3,s2);
MoveDisk(s1,s2);
MovePinnacle(n-1,s3,s2,s1);
end;
begin
var n:=5;
var p1:=new Pinnacle(1);
var p2:=new Pinnacle(2);
var p3:=new Pinnacle(3);
Range(n,1,-1).ForEach(i->p2.St.Push(i));
MoveNo:=0;
MovePinnacle(n,p2,p3,p1);
end.
Результат работы
1: №1 2 -> 3
2: №2 2 -> 1
3: №1 3 -> 1
4: №3 2 -> 3
5: №1 1 -> 2
6: №2 1 -> 3
7: №1 2 -> 3
8: №4 2 -> 1
9: №1 3 -> 1
10: №2 3 -> 2
11: №1 1 -> 2
12: №3 3 -> 1
13: №1 2 -> 3
14: №2 2 -> 1
15: №1 3 -> 1
16: №5 2 -> 3
17: №1 1 -> 2
18: №2 1 -> 3
19: №1 2 -> 3
20: №3 1 -> 2
21: №1 3 -> 1
22: №2 3 -> 2
23: №1 1 -> 2
24: №4 1 -> 3
25: №1 2 -> 3
26: №2 2 -> 1
27: №1 3 -> 1
28: №3 2 -> 3
29: №1 1 -> 2
30: №2 1 -> 3
31: №1 2 -> 3
Иллюстрация первых пяти шагов приведена во вложении.