Hướng dẫn giải của Cây cân bằng
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: Cây cân bằng
Hướng tiếp cận
Phân rã centroid kết hợp với matching đường đi qua centroid để tìm độ lồng tối đa.
Nhận xét quan trọng
- Với mỗi centroid , xét các đường đi (, ở hai cây con khác nhau).
- Phần trái (, không tính nhãn ): , , (prefix sum trên đoạn , bắt đầu từ 0).
- Hợp lệ: (tức đạt max trên đường đi).
- Phần phải (, không tính nhãn ): , .
- Hợp lệ: (tức đạt min).
- Cân bằng: .
- Độ lồng = .
Thuật toán
- Xử lý từng centroid : khởi tạo pool với "nửa rỗng" (kết thúc tại ).
- Với mỗi cây con của : match đường đi mới với pool → cập nhật đáp án → thêm vào pool.
- Đệ quy vào các cây con.
Độ phức tạp
- Thời gian:
- Bộ nhớ:
Bình luận