結果

問題 No.45 回転寿司
ユーザー yuki2006yuki2006
提出日時 2014-10-19 16:26:08
言語 C++11
(gcc 13.3.0)
結果
TLE  
実行時間 -
コード長 585 bytes
コンパイル時間 469 ms
コンパイル使用メモリ 59,988 KB
実行使用メモリ 13,696 KB
最終ジャッジ日時 2024-11-24 07:20:07
合計ジャッジ時間 175,637 ms
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 TLE -
testcase_01 TLE -
testcase_02 TLE -
testcase_03 TLE -
testcase_04 TLE -
testcase_05 TLE -
testcase_06 TLE -
testcase_07 TLE -
testcase_08 TLE -
testcase_09 TLE -
testcase_10 TLE -
testcase_11 TLE -
testcase_12 TLE -
testcase_13 TLE -
testcase_14 TLE -
testcase_15 TLE -
testcase_16 TLE -
testcase_17 TLE -
testcase_18 TLE -
testcase_19 TLE -
testcase_20 TLE -
testcase_21 TLE -
testcase_22 AC 2 ms
8,448 KB
testcase_23 AC 2 ms
8,448 KB
testcase_24 AC 1 ms
8,320 KB
testcase_25 AC 1 ms
8,448 KB
testcase_26 TLE -
testcase_27 TLE -
testcase_28 TLE -
testcase_29 TLE -
testcase_30 TLE -
testcase_31 AC 1 ms
5,248 KB
testcase_32 AC 2 ms
5,248 KB
testcase_33 TLE -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <cstring>
#include <string>
#define MAX_N 1000

int v[MAX_N];
int dp[MAX_N];
int limit;

int sushi(int n, bool last){
 int val;
 if(limit <= n) return 0;
 else if(last == true) val =  sushi(n+1, false); 
 else val = std::max(sushi(n+1,false), sushi(n+1,true) + v[n]);
 return (dp[n] = val);
}

int main(){
 memset(dp,-1,sizeof(dp));
 std::cin >> limit;
 for(register int i = 0; i < limit; i++){
   std::cin >> v[i];
 }
 printf("%d\n",sushi(0,false));
 std::cout.flush();
}
0