Tìm đoạn con có tổng k

Xem dạng PDF

Gửi bài giải

Điểm: 750,00 (OI)
Giới hạn thời gian: 1.0s
Giới hạn bộ nhớ: 256M
Input: stdin
Output: stdout

Nguồn bài:
Chuyên đề 1 - Tài liệu chuyên Tin - Quyển 1
Dạng bài
Ngôn ngữ cho phép
C, C++, Go, Java, Kotlin, Pascal, PyPy, Python, Rust, Scratch

Cho dãy gồm ~ n ~ số nguyên dương ~ a_1, a_2, \ldots, a_n ~ và một số nguyên ~ k ~.
Hãy tìm một đoạn con liên tiếp từ chỉ số ~ l ~ đến ~ r ~ sao cho tổng các phần tử trong đoạn đúng bằng ~ k ~.

Dữ liệu

  • Dòng đầu tiên chứa hai số nguyên ~ n ~ và ~ k ~ ~(1 \le n \le 10^5, 1 \le k \le 10^9)~.
  • Dòng thứ hai chứa ~ n ~ số nguyên dương ~ a_1, a_2, \ldots, a_n ~ ~(1 \le a_i \le 10^4)~.

Kết quả

  • Nếu tồn tại đoạn con liên tiếp thỏa mãn, in hai số nguyên ~ l ~ và ~ r ~ là chỉ số bắt đầu và kết thúc.
  • Nếu có nhiểu đoạn thỏa mãn thì chọn đoạn có chỉ số bắt đầu nhỏ nhất.
  • Nếu không tồn tại đoạn nào thỏa mãn, in -1.

Ví dụ

Input
5 12
1 2 3 7 5
Output
2 4
Input
5 20
1 2 3 4 5
Output
-1

Giải thích

  • Trong test ví dụ thứ nhất: Đoạn từ chỉ số ~2~ đến ~4~ có tổng ~ 2 + 3 + 7 = 12 ~.
  • Trong test ví dụ thứ hai: Không có đoạn con nào có tổng bằng ~20~.

Chấm điểm

Subtask Giới hạn Điểm
1 ~ n \le 100 ~, ~ k \le 10^4 ~ 30%
2 ~ n \le 2000 ~, ~ k \le 10^6 ~ 30%
3 ~ n \le 10^5 ~, ~ k \le 10^9 ~ 40%

Bình luận

Hãy đọc nội quy trước khi bình luận.


Không có bình luận tại thời điểm này.