Bờm đang lập trình cho một cánh tay robot để có thể dùng phấn vẽ lên trên bảng đen, coi bảng đen là một mặt phẳng tọa độ chuẩn Oxy (trục Ox tăng từ trái sang phải, trục Oy tăng từ dưới lên trên).
Kế hoạch mô tả các thao tác thực hiện của cánh tay robot là một mảng gồm vector , trong đó và là các số nguyên chẵn. Vận hành thực tế của cánh tay robot như sau: đầu tiên nó bắt đầu đặt viên phấn từ điểm và sau đó thực hiện bước, ở bước thứ , cánh tay robot sẽ di chuyển viên phấn trên bảng từ điểm hiện tại đến thẳng điểm . Ta có thể hình dung cánh tay robot đang vẽ một loại đường đứt đoạn trong mặt phẳng tọa độ, và các đoạn của đường đứt đoạn đó chính là các vector đã cho.
Trong khi Bờm đang nghĩ về cách thay đổi kế hoạch để thay đổi đường đứt đoạn mà robot có thể vẽ ra, anh ấy tự hỏi viên phấn sẽ đi qua các trục tọa độ bao nhiêu lần với đường robot sẽ vẽ ra với kế hoạch hiện tại. Do đó Bờm muốn có một chương trình mô phỏng quá trình thay đổi kế hoạch và trả lời các truy vấn số lần đi qua trục tọa độ với đường robot vẽ ra, để anh ấy có thể dễ dàng tùy chỉnh kế hoạch cho robot theo ý mình.
Giả sử kế hoạch mô tả các thao tác của robot chứa vector là một mảng đánh số từ đến . Ban đầu con trỏ của chương trình mô phỏng chỉ vào vị trí của mảng này. Và chương trình mô phỏng cần thực hiện các lệnh sau:
: lùi con trỏ về vị trí trước vị trí hiện tại trong mảng (nếu vị trí hiện tại là thì nó sẽ lùi về vị trí , nếu thì nó giữ nguyên vị trí hiện tại);
: di chuyển con trỏ đến vị trí tiếp theo trong mảng (nếu vị trí hiện tại là thì nó sẽ tiến đến vị trí , nếu thì nó giữ nguyên vị trí hiện tại);
: thay đổi vector của vị trí hiện tại của con trỏ trong mảng thành , với cũng là những số nguyên chẵn;
: trả lời câu hỏi của Bờm rằng với kế hoạch hiện tại thì đường robot sẽ vẽ ra có bao nhiêu lần đi qua trục tọa độ. Nếu đi qua gốc thì được tính là lần đi qua trục tọa độ.