Duyên hải Bắc Bộ 2026 - Dãy số

Nộp bài
Time limit: 1.0 / Memory limit: 1G

Point: 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ài
Time limit: 1.0 / Memory limit: 1G

Point: 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ài
Time limit: 1.0 / Memory limit: 1G

Point: 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ài
Time limit: 1.0 / Memory limit: 1G

Point: 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~.