結果

問題 No.561 東京と京都
ユーザー aaaaasatori
提出日時 2018-02-27 04:29:15
言語 Java
(openjdk 23)
結果
AC  
実行時間 154 ms / 2,000 ms
コード長 615 bytes
コンパイル時間 3,265 ms
コンパイル使用メモリ 77,684 KB
実行使用メモリ 54,484 KB
最終ジャッジ日時 2024-11-26 08:16:05
合計ジャッジ時間 6,943 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 17
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.util.Scanner;

public class No561 {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int N = sc.nextInt();
		int D = sc.nextInt();
		int t[] = new int[N];
		int k[] = new int[N];
		for(int i = 0;i < N;i++) {
			t[i] = sc.nextInt();
			k[i] = sc.nextInt();
		}
		int tmax[] = new int[N];
		int kmax[] = new int[N];
		tmax[0] = t[0];
		kmax[0] = k[0] - D;
		for(int i = 1;i < N;i++) {
			tmax[i] = Math.max(tmax[i-1] + t[i],kmax[i-1] + t[i] - D);
			kmax[i] = Math.max(kmax[i-1] + k[i],tmax[i-1] + k[i] - D);
		}
		System.out.println(Math.max(tmax[N-1], kmax[N-1]));
	}
}
0