Hướng dẫn giải của Bò nhảy Pogo
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: Bò nhảy Pogo
Hướng tiếp cận
Quy hoạch động với tối ưu hóa bằng kỹ thuật hai con trỏ (two pointers) để duy trì giá trị max chạy.
Nhận xét quan trọng
- Sắp xếp các mục tiêu theo vị trí. Ta xét riêng hai hướng: sang phải và sang trái.
- Định nghĩa = điểm tối đa khi bò nhảy đến mục tiêu và bước nhảy trước đó là từ đến (với khi đi sang phải).
- Chuyển tiếp: .
- Sử dụng running maximum và two pointers: khi giảm (khoảng cách tăng), con trỏ cũng giảm (ngưỡng khoảng cách tối thiểu tăng, nên ít mục tiêu hơn thỏa mãn), cho phép tính mỗi trạng thái.
Thuật toán
- Sắp xếp mục tiêu theo vị trí tăng dần.
- Chạy DP cho hướng phải: duyệt từ về , với mỗi duyệt từ đến , duy trì con trỏ và giá trị max chạy.
- Lặp lại cho hướng trái (đảo dấu tọa độ, reverse mảng).
- Đáp án là giá trị lớn nhất tìm được.
Độ phức tạp
- Thời gian:
- Bộ nhớ:
Bình luận