結果

問題 No.258 回転寿司(2)
ユーザー itezpace
提出日時 2016-10-29 07:42:01
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
AC  
実行時間 6 ms / 2,000 ms
コード長 735 bytes
コンパイル時間 515 ms
コンパイル使用メモリ 62,672 KB
実行使用メモリ 7,116 KB
最終ジャッジ日時 2024-11-06 19:09:28
合計ジャッジ時間 3,927 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 67
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <vector>
using namespace std;
int main(){
  int N=0;cin>>N;
  vector<int> v1(1000*N+1),v2(N+1);
  int V=0,a=0,b=0,c=0,d=0;
  for(int i=1;i<=N;++i){
    cin>>V;
    if(i<=2){
      d=V;
      v1[d]=i;
    } else {
      if(a>=b){
        d=a+V;
        v1[d]=i;
      } else {
        d=b+V;
        v1[d]=i;
      }
    }
    a=b;
    b=c;
    c=d;
    v2[i]=V;
  }
  vector<int> v3;
  for(int i=1000*N;i>=1;--i){
    if(v1[i]){
      cout<<i<<endl;
      int j=i;
      while(1){
        int e=v1[j];
        v3.push_back(e);
        if(e<=2) break;
        j-=v2[e];
      }
      break;
    }
  }
  for(int i=v3.size()-1;i>=0;--i){
    if(i!=v3.size()-1) cout<<" ";
    cout<<v3[i];
  }
  cout<<endl;
}
0