前提・実現したいこと
Atcorderの、Educational DP Contestの二問目、B-Frog 2でACを取りたい
Frog問題の、カエルの跳べる距離の最大値が、標準入力で与えられるバージョンの問題です。
https://atcoder.jp/contests/dp/tasks/dp_b
発生している問題・エラーメッセージ
16のテストケースのうち、13こがACで3こWAになってしまっています。
エラーメッセージ
該当のソースコード
Java
1import java.util.Scanner; 2 3public class Main { 4 public static void main(String args[]) { 5 Scanner sc = new Scanner(System.in); 6 7 // N:足場の数 8 // K:カエルの最大飛距離 9 int N = sc.nextInt(); 10 int K = sc.nextInt(); 11 12 final int INF = 100100100; 13 14 int[] h = new int[N]; 15 int[] dp = new int[N]; 16 17 for (int i = 0; i < N; i++) { 18 dp[i] = INF; 19 } 20 for (int i = 0; i < N; i++) { 21 h[i] = sc.nextInt(); 22 } 23 24 // 初期条件 25 dp[0] = 0; 26 27 // Kの最大値はN 28 if(N<K) { 29 K = N; 30 } 31 32 for (int i = 1; i < N; i++) { 33 // 2番目の足場は1番目の足場から遷移してくるのみ 34 if (i == 1) { 35 dp[i] = Math.abs(h[i] - h[i - 1]); 36 // test 37// System.out.println("i=" + i + " " + dp[i]); 38 } else { 39 // 最大K通りの遷移が考えられる 40 for (int j = 1; j <= K; j++) { 41 // i-j>0にしてしまうと、例えば、i=2,j=2のときを考慮できない 42 // iが0始まりであることに注意 43 if (i >= j) { 44 dp[i] = Math.min(dp[i], dp[i - j] + Math.abs(h[i] - h[i - j])); 45 // test 46// System.out.println("i=" + i + " " + dp[i]); 47 } 48 } 49 } 50 } 51 System.out.println(dp[N-1]); 52 } 53}
試したこと
他の方の提出したJavaでACになっているソースコードと比較しましたが、行っている処理は同じように思えました。
また、AtCorderの解説を見ましたが、そこでも行っている処理は同じように思えました。
補足情報(FW/ツールのバージョンなど)
テストケースの中身がわかれば、おそらく、解決するのですが調べてもテストケースは見当たりませんでした。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2022/01/07 04:45
2022/01/07 08:17
2022/01/11 00:45