Duyên hải Bắc Bộ 2026
Duyên hải Bắc Bộ 2026 - Dãy số
Nộp bàiPoint: 100
Trong trường hợp đề bài hiển thị không chính xác, bạn có thể tải đề bài tại đây: Đề bài
Alice tạo dãy số nguyên ~a_1, a_2, \dots, a_N~, cô cần thống kê số bộ ba chỉ số ~(i, j, k)~ thỏa mãn hai điều kiện sau:
~1 \le i < j < k \le N~.
~a_i \le a_j \ge a_k~ hoặc ~a_i \ge a_j \le a_k~.
Yêu cầu: Cho dãy gồm ~N~ số nguyên ~a_1, a_2, \dots, a_N~, hãy đếm số lượng bộ ba thỏa mãn.
Input
Dòng đầu chứa số nguyên dương ~N~ (~N \le 3 \times 10^5~).
Dòng thứ hai chứa ~N~ số nguyên ~a_1, a_2, \dots, a_N~ (~|a_i| \le 10^9~).
Output
Một số nguyên là số lượng bộ ba thỏa mãn.
Scoring
| Subtask | Điểm | Ràng buộc |
|---|---|---|
| 1 | ~10\%~ | ~N = 3~ |
| 2 | ~30\%~ | ~N \le 300~ |
| 3 | ~30\%~ | ~N \le 3000~ |
| 4 | ~30\%~ | Không có ràng buộc nào thêm |
Sample Input 1
3
1 2 3
Sample Output 1
0
Sample Input 2
4
1 3 2 4
Sample Output 2
2
Sample Input 3
4
1 1 1 1
Sample Output 3
4
Duyên hải Bắc Bộ 2026 - Đường đi
Nộp bàiPoint: 100
Trong trường hợp đề bài hiển thị không chính xác, bạn có thể tải đề bài tại đây: Đề bài
Alice mới tạo ra một trò chơi tìm đường đi trên mặt phẳng tọa độ. Cụ thể, một nhân vật xuất phát tại vị trí ~(x_s, y_s)~ cần di chuyển tới vị trí ~(x_t, y_t)~ trong thời gian ngắn nhất. Tại mỗi đơn vị thời gian, giả sử nhân vật đang ở vị trí ~(x_1, y_1)~ thì có thể di chuyển tới vị trí ~(x_2, y_2)~ nếu ~\max(|x_1 - x_2|, |y_1 - y_2|) = 1~. Để trò chơi thêm thú vị, Alice đặt ~K~ vật phẩm ở ~K~ vị trí ~(u_1, v_1), (u_2, v_2), \dots, (u_K, v_K)~, ngoài việc di chuyển với thời gian ngắn nhất, người chơi cần chọn đường đi để thu thập được nhiều vật phẩm nhất. Nhân vật di chuyển tới vị trí có vật phẩm sẽ thu thập được vật phẩm ở vị trí đó và thời gian thu thập là không đáng kể.
Yêu cầu: Cho các thông tin ~(x_s, y_s), (x_t, y_t)~ và ~(u_1, v_1), (u_2, v_2), \dots, (u_K, v_K)~, hãy tìm đường đi từ vị trí ~(x_s, y_s)~ đến ~(x_t, y_t)~ với thời gian ngắn nhất, trong số các đường đi ngắn nhất đó, chọn con đường đi qua nhiều vị trí chứa vật phẩm nhất.
Input
Dòng đầu chứa năm số nguyên ~x_s, y_s, x_t, y_t, K~ (~|x_s|, |y_s|, |x_t|, |y_t| \le 10^9; K \le 10^5~);
Dòng thứ ~i~ trong ~K~ dòng sau chứa hai số nguyên ~u_i, v_i~ (~|u_i|, |v_i| \le 10^9~).
Output
Gồm một số nguyên không âm là số vật phẩm nhiều nhất có thể thu thập được.
Scoring
| Subtask | Điểm | Ràng buộc |
|---|---|---|
| 1 | ~25\%~ | ~K \le 10~ |
| 2 | ~25\%~ | ~K \le 20~ |
| 3 | ~25\%~ | ~K \le 3000~ |
| 4 | ~25\%~ | Không có ràng buộc nào thêm. |
Sample Input 1
0 0 4 0 3
1 1
3 -1
2 0
Sample Output 1
3
Sample Input 2
0 0 4 0 4
1 1
2 2
2 0
3 -1
Sample Output 2
3
Sample Input 3
0 0 2 2 1
0 1
Sample Output 3
0
Notes
Ví dụ 1: ~(0, 0) \to (1, 1) \to (2, 0) \to (3, -1) \to (4, 0)~
Ví dụ 2: ~(0, 0) \to (1, 1) \to (2, 0) \to (3, -1) \to (4, 0)~
Ví dụ 3: ~(0, 0) \to (1, 1) \to (2, 2)~
Duyên hải Bắc Bộ 2026 - Đổ nước
Nộp bàiPoint: 100
Trong trường hợp đề bài hiển thị không chính xác, bạn có thể tải đề bài tại đây: Đề bài
Alice có ~N~ bình nước giống nhau, mỗi bình có thể chứa được ~V~ lít nước. Hiện tại, bình thứ ~i~ (~1 \le i \le N~) chứa ~v_i~ lít nước (~v_1 + v_2 + \dots + v_N = V~). Alice muốn thực hiện một dãy các lần đổ nước giữa các bình để số lượng bình rỗng là nhiều nhất. Mỗi lần cô có thể đổ nước từ bình ~i~ sang bình ~j~ nếu ~v_i \ge v_j~ một lượng nước bằng ~v_j~ lít, sau khi đổ bình ~i~ còn ~v_i - v_j~ lít, bình ~j~ có ~2v_j~ lít.
Yêu cầu: Hãy tìm một dãy các lần đổ nước để số bình rỗng là nhiều nhất.
Input
Dòng đầu chứa số nguyên ~T~ (~T \le 10~) là số bộ dữ liệu, tiếp theo là các nhóm dòng, mỗi nhóm có khuôn dạng:
Dòng đầu của nhóm chứa số nguyên dương ~N~ (~2 \le N \le 10~).
Dòng thứ hai của nhóm chứa ~N~ số nguyên dương ~v_1, v_2, \dots, v_N~ (~v_1 + v_2 + \dots + v_N = V \le 10^{12}~).
Output
Gồm ~T~ nhóm dòng, mỗi nhóm mô tả lời giải tương ứng một bộ dữ liệu theo khuôn dạng:
Dòng đầu ghi số nguyên ~S~ là số lần đổ nước;
Dòng thứ ~t~ (~1 \le t \le S~) trong ~S~ dòng sau, mỗi dòng ghi hai số ~i, j~ cho biết lần đổ thứ ~t~ đổ nước từ bình ~i~ sang bình ~j~.
Scoring
| Subtask | Điểm | Ràng buộc |
|---|---|---|
| 1 | ~20\%~ | ~N = 3~ và ~V \le 300~ |
| 2 | ~20\%~ | ~N = 3~ và ~V \le 3000~ |
| 3 | ~20\%~ | ~V \le 3000~ |
| 4 | ~20\%~ | ~N = 3~ |
| 5 | ~20\%~ | Không có ràng buộc nào thêm. |
Sample Input 1
2
3
1 2 3
4
1 1 1 1
Sample Output 1
2
3 1
2 1
3
2 3
1 4
4 3
Notes
Với bộ dữ liệu thứ nhất có thể nhận được 1 bình rỗng. ~(1, 2, 3) \to (2, 2, 2) \to (2, 0, 4)~
Với bộ dữ liệu thứ hai có thể nhận được 3 bình rỗng. ~(1, 1, 1, 1) \to (2, 0, 2, 0) \to (4, 0, 0, 0)~
Duyên hải Bắc Bộ 2026 - Hái táo
Nộp bàiPoint: 100
Trong trường hợp đề bài hiển thị không chính xác, bạn có thể tải đề bài tại đây: Đề bài
Một cây táo được biểu diễn bằng một đồ thị dạng cây. Đồ thị liên thông có ~N~ đỉnh và ~N - 1~ cạnh, trong đó đỉnh thứ ~i~ (~1 \le i \le N~) có trọng số là số nguyên dương ~w_i~ biểu diễn có một quả táo ở vị trí đó với khối lượng là ~w_i~ (gram). Alice chỉ có thể mang được không quá ~S~ gram nên cô muốn chọn hái một số quả táo thỏa mãn:
Tổng khối lượng các quả chọn hái là không quá ~S~.
Hai quả được chọn hái không kề nhau.
Yêu cầu: Hãy chọn hái các quả để tổng khối lượng các quả càng lớn càng tốt.
Input
Dòng đầu chứa hai số nguyên dương ~N, S~ (~N \le 1000; S \le 10^9~).
Dòng thứ hai chứa ~N~ số nguyên dương ~w_1, w_2, \dots, w_N~ (~w_i \le 10^9~).
~N - 1~ dòng tiếp theo, mỗi dòng chứa hai số nguyên ~u, v~ (~1 \le u, v \le N~) mô tả các cạnh của cây.
Dữ liệu đảm bảo luôn tồn tại cách chọn để đạt được tổng bằng ~S~.
Output
Dòng đầu ghi số nguyên ~K~ là số quả chọn hái.
Dòng thứ hai chứa ~K~ số là chỉ số các quả chọn hái.
Scoring
| Subtask | Điểm | Ràng buộc |
|---|---|---|
| 1 | ~20\%~ | ~N \le 40; S \le 10^4~ và cây có dạng đường thẳng. |
| 2 | ~20\%~ | ~N \le 40; S \le 10^4~. |
| 3 | ~20\%~ | ~S \le 10^6~ và cây có dạng đường thẳng. |
| 4 | ~30\%~ | ~S \le 10^6~. |
| 5 | ~10\%~ | Không có ràng buộc nào thêm. |
Đây là bài toán chấm điểm theo tỉ lệ tối ưu. Gọi tổng khối lượng các quả táo chọn hái do thí sinh tìm được là ~P~, khi đó phần trăm số điểm đạt được cho mỗi test là $$\frac{P}{S} \times 100\%$$
Sample Input 1
5 10
3 7 2 8 5
1 2
2 3
3 4
4 5
Sample Output 1
3
1 3 5
Notes
Chọn hái quả ~1~, ~3~ và quả ~5~, tổng khối lượng là ~3 + 2 + 5 = 10~.