(lis.*)
Dãy con tăng dài nhất của dãy \(a_{1},\ a_{2},\ \ldots,a_{n}\) là dãy \({1 \leq p}_{1} < \ p_{2} < \ \ldots < p_{k} \leq n\) (trong đó \(k\) là số nguyên lớn nhất) sao cho \(a_{p_{1}} < a_{p_{2}} < \ldots < a_{p_{k}}\). Sau khi được học về bài toán dãy con tăng dài nhất, là một học sinh thông minh, thích khám phá nhiều điều mới lạ nên An đã thay đổi một chút nội dung của bài toán này. Trước tiên, An chọn một đoạn con liên tiếp trong dãy \(a_{1},\ a_{2},\ \ldots,a_{n}\) và một số nguyên \(d\ ( - x \leq \ d \leq x)\). An thực hiện tăng giá trị các phần tử trong đoạn con đó lên \(d\) (\(d\) có thể bằng 0). Sau phép biến đổi, độ dài của dãy con tăng dài nhất sẽ dài hơn và An muốn biết độ dài này là bao nhiều. Các bạn hãy viết chương trình giúp An nhé!
Dữ liệu vào:
Dòng đầu gồm hai số nguyên \(n\) và \(x\) \((1\ \leq n\ \leq \ 200000;\ 0\ \leq x\ \leq \ 10^{9})\) lần lượt là độ dài của dãy ban đầu và giới hạn cho giá trị \(d\).
Dòng thứ hai gồm \(n\) số nguyên \(a_{1},\ a_{2},\ \ldots,a_{n}\ \left( 1 \leq a_{i} \leq 10^{9},\ i = 1..n \right)\)
Các số trên một dòng của input file được ghi cách nhau bởi dấu cách.
Kết quả: ghi một số nguyên duy nhất là độ dài của dãy con tăng dài nhất sau phép biến đổi.
Ví dụ:
Input | Output |
---|---|
8 10 7 3 5 12 2 7 3 4 |
5 |
Ràng buộc:
30% số điểm tương ứng với 30% số test có \(n \leq \ 1000\);
30% số điểm tương ứng với 30% số test có \(x\ =\) 0;
40% số điểm tương ứng với 40% số test không có ràng buộc gì thêm.
Code tích cực |
---|
Trong 24h |
Trong 7 ngày |
|
Trong 30 ngày |
|
Thống kê |
---|
AC/Sub: 97887/180710 Pascal: 17121 C++: 130348 Python: 33199 Lượt xem/tải tests: 38905 |