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

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

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

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

Q&A

解決済

1回答

2127閲覧

AtCoderの例題でREになる

ozraru

総合スコア150

Java

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

0グッド

0クリップ

投稿2020/09/05 05:13

編集2020/09/05 12:46

AtCoder practice contest B - Interactive Sorting
https://atcoder.jp/contests/practice/
https://atcoder.jp/contests/practice/tasks/practice_2(ログインして参加登録していないと見れないようです)
この問題を試していて、下のようなコードを書きましたが、REになってしまいます。

(追記) 全てのテストケースでREになります

自環境で試しても問題なく、原因がわかりません。

解決法と、なぜREになってしまうのか教えてほしいです。

###REになるソースコード

Java

1import java.io.PrintStream; 2import java.util.ArrayList; 3import java.util.Scanner; 4 5public class Main { 6 static PrintStream o = System.out; 7 static Scanner sc = new Scanner(System.in); 8 static char[] chars; 9 10 private static boolean query(int from, int compare) { //fromが大きければtrue 11 o.println("? "+chars[from]+" "+chars[compare]); 12 if (sc.nextLine().equals(">")) { 13 return true; 14 } else { 15 return false; 16 } 17 } 18 19 public static void main(String[] args) { 20 short amount = sc.nextShort(); 21 sc.nextLine(); 22 chars = new char[amount]; 23 for (int i = 0; i < amount; i++) { 24 chars[i] = (char) ('A' + i); 25 } 26 ArrayList<Integer> res = new ArrayList<Integer>(amount); 27 for (int i = 0; i < amount; i++) { // iはA=0,B=1,C=2... 28 int min = 0; //resのインデックスの最小値 29 int max = i; //resのインデックスの最大値 30 while (true) { 31 if (min == max) { 32 res.add(min, i); 33 break; 34 } 35 int compareTo = min + ((max-min) / 2); 36 if (query(i, res.get(compareTo))) { 37 min = compareTo+1; 38 } else { 39 max = compareTo; 40 } 41 } 42 } 43 String result = "! "; 44 for (Integer integer : res) { 45 result += chars[integer]; 46 } 47 o.println(result); 48 } 49}

テストと開発に使った自環境

Eclipse IDE for Java Developers 2020-06 (4.16.0)
Java 11.0.8
openjdk version "11.0.8"

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

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

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

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

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

guest

回答1

0

ベストアンサー

Q回を超えて質問クエリを出力する場合があるので、その場合でしょうか。

Text

15 7 2EDCBA

のとき

Text

1? B A 2< 3? C A 4< 5? C B 6< 7? D B 8< 9? D C 10< 11? E B 12< 13? E C 14< 15? E D 16< 17! EDCBA

投稿2020/09/05 11:17

yudedako67

総合スコア2047

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

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

ozraru

2020/09/05 12:47

すみません、言葉足らずでした... 70全てのテストケースでREになります。
yudedako67

2020/09/05 13:26

そのままコピペして出しても再現しないです。
ozraru

2020/09/05 16:10

?! 提出した方のpackage宣言消し忘れたからだったようです これの前のソースで消しても消さなくても全てREだったので勘違いして無視していたようです お手数おかけしました...
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問