結果
| 問題 |
No.45 回転寿司
|
| ユーザー |
jp_ste
|
| 提出日時 | 2016-05-08 23:42:53 |
| 言語 | Java (openjdk 23) |
| 結果 |
AC
|
| 実行時間 | 216 ms / 5,000 ms |
| コード長 | 1,089 bytes |
| コンパイル時間 | 3,750 ms |
| コンパイル使用メモリ | 76,816 KB |
| 実行使用メモリ | 42,364 KB |
| 最終ジャッジ日時 | 2024-12-27 13:20:42 |
| 合計ジャッジ時間 | 10,181 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 30 |
ソースコード
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
try (Scanner scan = new Scanner(System.in)) {
int n = scan.nextInt();
int list[] = new int[n];
int dp[] = new int[n];
for(int i=0; i<n; i++) {
list[i] = scan.nextInt();
dp[i] = list[i];
}
if(n == 1) {
System.out.println(list[0]);
} else if(n == 2){
if(list[0] > list[1]) System.out.println(list[0]);
else System.out.println(list[1]);
} else {
for(int i=2; i<n; i++) {
for(int j=0; j<=i-2; j++) {
if(dp[j] + list[i] > dp[i]) dp[i] = dp[j] + list[i];
}
}
int ans = 0;
for(int i=0; i<n; i++) {
ans = Math.max(ans, dp[i]);
}
System.out.println(ans);
}
}
}
}
jp_ste