Cho một xâu s có độ dài n (n chẵn) chỉ bao gồm các chữ cái Latin viết hoa 'A ', 'B ' và 'C '. Mỗi lượt bạn có thể thực hiện một trong hai hành động sau:
Bạn có thể xóa chính xác một chữ cái 'A ' và chính xác một chữ cái 'B ' khỏi các vị trí tùy ý của chuỗi (các chữ cái này không nhất thiết phải liền kề nhau);Hoặc bạn có thể xóa chính xác một chữ cái 'B ' và chính xác một chữ cái 'C ' khỏi các vị trí tùy ý của chuỗi (các chữ cái này không nhất thiết phải liền kề nhau).Do đó, độ dài của xâu giảm đi đúng một lượng là 2 chữ cái. Tất cả các lượt đều độc lập nên đối với mỗi lượt, bạn có thể chọn bất kỳ hành động nào trong hai hành động có thể.
Ví dụ, với s = "ABCABC " anh ta có thể nhận được một xâu s = "ACBC " trong một lượt (bằng cách xóa lần xuất hiện đầu tiên của 'B ' và lần xuất hiện thứ hai của 'A '). Ngoài ra còn có nhiều tùy chọn khác để thực hiện ngoài ví dụ cụ thể này.
Với xâu kí tự s đã cho bạn có thể xác định rằng liệu có cách thực hiện các thao tác trên để biến xâu s thành rỗng hay không. Nếu có thì in ra 'YES' còn không có thì in ra 'NO'.
InputDòng đầu tiên chứa 2 số nguyên dương n . (1≤n≤100000) - thể hiện chiều dài của xâu.Dòng thứ 2 chứa xâu s .OutputMột dòng duy nhất là 'YES' hoặc 'NO' tương ứng là có hoặc không có cách thực hiện các thao tác đã cho để biến xâu s thành rỗng.Ví dụ 1:
Input:
Copy6 ABACABOutput:
CopyNO
- 1. Đọc và kiểm tra dữ liệu đầu vào:
- Đọc \(N\) và \(M\) từ dòng đầu tiên của file BAI3.INP.
- Kiểm tra điều kiện \(1 < N, M \le 100\). Nếu không thỏa mãn, ghi -1 ra file BAI3.OUT và kết thúc.
- Đọc ma trận từ các dòng tiếp theo của file.
- 2. Xử lý từng hàng:
- Lặp qua từng hàng của ma trận (từ 0 đến \(N-1\)).
- Trong mỗi hàng:
- Khởi tạo
- Lặp qua các phần tử trong hàng (từ 0 đến \(M-1\)):
- Nếu giá trị hiện tại lớn hơn
- Cập nhật max_val với giá trị hiện tại.
- Xóa danh sách positions và thêm vị trí hiện tại vào.
- Nếu giá trị hiện tại bằng
- Thêm vị trí hiện tại vào danh sách positions.
- Ghi kết quả:
- Ghi
- 3. Xử lý lỗi:
- Nếu không tìm thấy file, hoặc dữ liệu không hợp lệ (không phải số nguyên), chương trình sẽ ghi -1 ra file BAI3.OUT.
Ví dụ: Giả sử file BAI3.INP có nội dung: Mã File BAI3.OUT sẽ có nội dung: Mãmax_val
là giá trị nhỏ nhất có thể (- vô cùng) và một danh sách rỗngpositions
.max_val
:max_val
:max_val
và các vị trí trongpositions
ra file BAI3.OUT, cách nhau bởi dấu cách.