이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
#define ll long long
ll findlis(vector<ll> v){
ll sz = v.size(), maxlen = 0, len;
stack<ll> st;
st.push(-3e9);
for(int i = 0; i < sz; i++){
if(st.top() >= v[i]){
while(st.top() >= v[i]){
st.pop();
}
}
st.push(v[i]);
len = st.size()-1;
maxlen = max(len, maxlen);
}
return maxlen;
}
int main(){
vector<ll> t, temp;
ll n, x, input, maxlis = 0;
cin >> n >> x;
for(int i = 0; i < n; i++){
cin >> input;
t.push_back(input);
}
if(x == 0){
cout << findlis(t) << endl;
return 0;
}
for(int k = x*(-1); k <= x; k++){
for(int l = 0; l < n; l++){
temp = t;
for(int r = l; r < n; r++){
temp[r] += k;
maxlis = max(maxlis, findlis(temp));
}
}
}
cout << maxlis;
}
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |