HCT05 - Tân binh - FORMATION
Dữ liệu vào: Standard input
Dữ liệu ra: Standard output
Giới hạn thời gian: 1.0 giây
Giới hạn bộ nhớ: 128 megabyte
Đăng bởi: phanhieubl

Bên phaaaaải quay!” “Bên traaaaái quay!” ‘Đằng saaaau quay!” Người trung sỹ hô rát họng nhưng đám tân binh vẫn quay láo nháo, không phân biệt đâu là bên phải, đâu là bên trái, cũng có thể họ nghĩ rằng “Bên trái quay!” là quay sang phía bên trái của người cạnh mình. Cuối cùng thì trung sỹ cũng hiểu ra rằng trước mặt mình là lớp người thế hệ Internet, chỉ quen nhấp chuột và hiểu rất nhanh các lệnh lập trình, chơi trò chơi trên máy tính cực kỳ thành thạo. Anh quyết định thay đổi cách huấn luyện và việc đầu tiên là dạy họ phân biệt bên phải bên trái.

Trung sỹ đánh số mọi người từ 1 đến n (1 ≤ n ≤ 1.000.000) và chia làm hai nhóm “đứng trong hàng” và “đám đông”. Ban đầu trong hàng chỉ có ngưới số 1. Những người đứng trong hàng tạo thành một hàng ngang và quay mặt về một phía. Trung sỹ ra lệnh và mọi người thực hiện. Mỗi lệnh có một trong 4 dạng sau:

  • Left(i,j) – người i trong đám đông chạy vào hàng và đứng bên trái, cạnh người j,
  • Right(i,j) –  người i trong đám đông chạy vào hàng và đứng bên phải người j
  • Leave(i) – người i ra khỏi hàng trở về đám đông,
  • Name(i) – yêu cầu người i nói số của người bên trái và số của người bên phải mình. Nếu i đứng ở đầu hoặc cuối hàng thì một trong hai số cần nói sẽ là 0.

Các câu lệnh đều đúng ngữ cảnh và hàng không bao giờ rỗng.

Đôi khi hàng trở nên quá lớn và trung sỹ không biết được câu trả lời của người tân binh là đúng hay sai.

Yêu cầu: Cho n, số câu lệnh m (1 ≤ m ≤ 1.000.000) và các câu lệnh theo trình tự cần thực hiện. Hãy đưa ra kết quả các câu lệnh dạng name i.

Dữ liệu: Vào từ file văn bản FORMATION.INP:

  • Dòng đầu tiên chứa 2 số nguyên nm,
  • Mỗi dòng trong m dòng sau chứa một câu lệnh, trong đó câu lệnh được mã hóa như sau:

Lệnh

Số mã hóa

Left

1

Right

2

Leave

3

Name

4

 

Kết quả: Đưa ra file văn bản FORMATION.OUT, mỗi dòng chứa 2 số nguyên là  kết quả câu lệnh name i.

Ví dụ

Back to Top