이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "shortcut.h"
#include "bits/stdc++.h"
using namespace std;
typedef long long ll;
#define N 100007
#define INF 1000000000007
ll a[10*N],b[10*N],a1[10*N],b1[10*N],t[10*N],ma[10*N],mb[10*N];
long long find_shortcut(int n, std::vector<int> k, std::vector<int> d, int c)
{
for(int i=1;i<n;i++){
a[i]=k[i-1];
b[i]=d[i-1];
t[i]=t[i-1]+a[i-1];
ma[i]=max(ma[i-1],a1[i-1]+a[i-1]+b[i]);
a1[i]=max(a1[i-1]+a[i-1],b[i]);
}
b[n]=d[n-1];
t[n]=t[n-1]+a[n-1];
ma[n]=max(ma[n-1],a1[n-1]+a[n-1]+b[n]);
a1[n]=max(a1[n-1]+a[n-1],b[n]);
for(int i=n;i>=1;i--){
mb[i]=max(mb[i+1],b1[i+1]+a[i]+b[i]);
b1[i]=max(b[i],b1[i+1]+a[i]);
}
b[n]=d[n-1];
ll prew=INF;
ll res=ma[n];
// cout<<res<<endl;
for(int l=1;l<=n;l++){
for(int r=l+1;r<=n;r++){
res=min(res,max(ma[r-1],max(mb[l+1],min(ll(c),t[r]-t[l])+a1[l]+b1[r])));
//cout<<l<<" "<<r<<" "<<res<<" "<<ma[r-1]<<" "<<mb[l+1]<<" "<<a1[l]<<" "<<b1[r]<<" "<<t[r]-t[l]<<endl;
}
}
return res;
}
컴파일 시 표준 에러 (stderr) 메시지
shortcut.cpp: In function 'long long int find_shortcut(int, std::vector<int>, std::vector<int>, int)':
shortcut.cpp:32:8: warning: unused variable 'prew' [-Wunused-variable]
32 | ll prew=INF;
| ^~~~
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |