Hướng dẫn giải của Chuỗi cân bằng đồng thời
Chỉ dùng lời giải này khi không có ý tưởng, và đừng copy-paste code từ lời giải này. Hãy tôn trọng người ra đề và người viết lời giải.
Nộp một lời giải chính thức trước khi tự giải là một hành động có thể bị ban.
Nộp một lời giải chính thức trước khi tự giải là một hành động có thể bị ban.
Lời giải: Chuỗi cân bằng đồng thời
Hướng tiếp cận
Dùng stack đơn điệu và map prefix-vector để đếm các cặp đoạn đồng thời hợp lệ.
Nhận xét quan trọng
- Đoạn hợp lệ với chuỗi ↔ tổng tiền tố và .
- Vị trí "chết" với chuỗi khi : duy trì stack đơn điệu per chuỗi để loại bỏ.
- Map từ vector tiền tố → số vị trí còn sống: đếm các có cùng prefix vector với .
Thuật toán
Duyệt từ 0 đến :
- Pop từ stack của mỗi chuỗi các vị trí với → đánh dấu chết, xóa khỏi map.
ans += map[vec(j)].- Thêm vào map và tất cả stack.
Độ phức tạp
- Thời gian:
- Bộ nhớ:
Bình luận