質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

1194閲覧

AtCorderのFrog問題について

tanaka.moments

総合スコア1

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2022/01/07 02:07

前提・実現したいこと

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/ツールのバージョンなど)

テストケースの中身がわかれば、おそらく、解決するのですが調べてもテストケースは見当たりませんでした。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

最大値宣言が甘いのでは?

投稿2022/01/07 04:06

swordone

総合スコア20669

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tanaka.moments

2022/01/07 04:45

まさにその通りでした。10^4 * 10^5なので最大10^9まで考えられました。INFを一桁増やして、INF=1001001001にしてみたらACになりました。
swordone

2022/01/07 08:17

というか、Integer.MAX_VALUEを指定すればそれでいいのでは?
tanaka.moments

2022/01/11 00:45

確かに、ほかの方のソースでもそうなっていました。次からはそうしてみます
guest

0

java

1dp[i] = Math.min(dp[i], dp[i - j] + Math.abs(h[i] - h[i - j]));

このあたりで桁あふれ起こしていそうですね。int型ではなくlong型を利用しても問題は再現しますか?

投稿2022/01/07 02:17

neko_the_shadow

総合スコア2349

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tanaka.moments

2022/01/07 02:26

回答ありがとうございます。 hとdpの2つの配列をlong型で定義し直してみましたが、全く同じテストケースにてWAが出てしまいました
tanaka.moments

2022/01/07 02:33

他の方の提出ソースコードでも、配列はintで定義しているため、そこで問題が発生しているとは考えにくいと思われます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問