結果
問題 |
No.919 You Are A Project Manager
|
ユーザー |
|
提出日時 | 2019-10-25 23:11:40 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,385 bytes |
コンパイル時間 | 1,014 ms |
コンパイル使用メモリ | 88,908 KB |
実行使用メモリ | 14,016 KB |
最終ジャッジ日時 | 2024-09-13 08:25:44 |
合計ジャッジ時間 | 26,684 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | -- * 3 |
other | AC * 26 TLE * 3 -- * 26 |
コンパイルメッセージ
main.cpp:7:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type] 7 | main() | ^~~~
ソースコード
#include<iostream> #include<algorithm> #include<vector> #include<queue> using namespace std; int N; main() { cin>>N; vector<int>A(N); for(int i=0;i<N;i++)cin>>A[i]; long ans=0; for(int K=1;2*K<=N;K++) { vector<long>L(N/K),R(N/K); vector<int>a=A; for(int i=0;i*K+K<=N;i++) { sort(a.begin()+i*K,a.begin()+i*K+K); L[i]=a[i*K+(K-1)/2]; } a=A; reverse(a.begin(),a.end()); for(int i=0;i*K+K<=N;i++) { sort(a.begin()+i*K,a.begin()+i*K+K); R[i]=a[i*K+(K-1)/2]; } for(int i=1;i<N/K;i++) { L[i]+=L[i-1]; R[i]+=R[i-1]; } for(int i=1;i<N/K;i++) { L[i]=max(L[i],L[i-1]); R[i]=max(R[i],R[i-1]); } for(int i=-1;i<N/K;i++) { int j=N/K-i-2; ans=max(ans,((i<0?0L:L[i])+(j<0?0L:R[j]))*K); } } { priority_queue<int>L; priority_queue<int,vector<int>,greater<int> >R; for(int i=0;i<N;i++) { if(L.size()==R.size()) { R.push(A[i]); int t=R.top();R.pop(); L.push(t); } else { L.push(A[i]); int t=L.top();L.pop(); R.push(t); } ans=max(ans,(long)L.top()*(i+1)); } } { priority_queue<int>L; priority_queue<int,vector<int>,greater<int> >R; for(int i=0;i<N;i++) { if(L.size()==R.size()) { R.push(A[N-i-1]); int t=R.top();R.pop(); L.push(t); } else { L.push(A[N-i-1]); int t=L.top();L.pop(); R.push(t); } ans=max(ans,(long)L.top()*(i+1)); } } cout<<ans<<endl; }