begin
var N, A, B, C, D: integer;
Readln(N, A, B, C, D);
if A > C then (A, B, C, D) := (C, D, B, A);
var s := 1.To(A - 1);
if B < C then // ( ) [ ]
s := s + B.Downto(A) + (B + 1).To(C - 1) +
D.Downto(C) + (D + 1).To(N)
else
if D < B then // ( [ ] )
begin
s := s + SeqGen(C - A, t -> B - t) +
SeqGen(D - C + 1, t -> t + A + B - D) +
SeqGen(B - D, t -> A - t + B - D - 1) + (B + 1).To(N)
end
else // ( [ ) ]
begin
s := s + SeqGen(C - A, t -> B - t) +
SeqGen(D - B, t -> D - t) + SeqGen(B - C + 1, t -> A + t) +
(D + 1).To(N);
end;
s.Println;
end.
Чтоб вернуться в ту же точку, надо чтоб смещение было (0;0)
1)
dx = 0 = 2(x1+3+2)-6 = 2x1+4 = 0, x1=-2
dy = 0 = 2(y1+2+1)-4 = 2y1+2 = 0, y1=-1
Команда1 = Сместиться на (-2,-1)
2)
dx = 0 = 4(x1+3+1)-8 = 4x1+8 = 0, x1=-2
dy = 0 = 4(y1+3-2)+12 = 4y1+16 = 0, y1=-4
Команда1 = Сместиться на (-2,-4)