Hướng dẫn giải của Chặn Đườ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: Chặn Đường
Hướng tiếp cận
Chỉ cần thử nhân đôi các cạnh nằm trên đường đi ngắn nhất ban đầu.
Nhận xét quan trọng
Nếu nhân đôi cạnh không nằm trên đường ngắn nhất, đường ngắn nhất không thay đổi → tăng = 0.
Thuật toán
- Chạy Dijkstra tìm đường ngắn nhất từ 1 đến , lưu đường đi.
- Với mỗi cạnh trên đường đi (tối đa cạnh):
- Nhân đôi trọng số cạnh đó.
- Chạy lại Dijkstra tìm đường ngắn nhất mới.
- Ghi nhận độ tăng.
- In độ tăng lớn nhất.
Độ phức tạp
- Thời gian: hoặc với Dijkstra đơn giản
- Bộ nhớ:
Bình luận