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

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

ただいまの
回答率

90.12%

Java nextintとnextlineについて

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,734

sG3s4

score 12

javaに関しての質問です
下記のコードのjava.util.ScannerのnextInt()とnextLine()は同時実装できないんでしょうか?
他にも問題点はたくさんあるのですが、とりあえず上記の部分だけお願いいたします。

package HmwkHmwk;

import java.util.InputMismatchException;
import java.util.Scanner;

public class Cst {
    public static void main(String[] args) {

    //スキャナーを使う
        Scanner sc = new Scanner(System.in);    

        try {
            String[] str = {"exit","quit"};

        while(!str.equals( sc.nextLine() )) {
            int n = sc.nextInt(); //ここでInputMismacthが起きる

            if(n < 71) {
                 System.out.println(n+"番目のフィボナッチ数は:"+ Cst2.fbnt(n));
                 System.out.println(n+"番目までのフィボナッチ数列は:"+Cst2.fbn(n));

            }else {

                 System.out.println("範囲外です");
            }

        }
        sc.close();
            System.out.println(str +"が入力されたので処理を終了します");

        }catch(InputMismatchException misma) {
            System.out.println(misma);
        }
    }


これを実行するとInputMismacthExeptionが出てきてしまいますどうしたらいいでしょうか?

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • sG3s4

    2018/02/08 02:59

    exitを入力するとjava.lang.NumberFormatException: For input string: "exit" このように表示されます

    キャンセル

  • swordone

    2018/02/08 03:04

    「具体的な入力例」を聞いているのですが?

    キャンセル

  • swordone

    2018/02/08 03:04

    あと、ここだと改行が適用されないので、質問編集で記載してください。

    キャンセル

回答 2

+2

Scanner#nextIntは改行文字をバッファに残します。
改行文字を空読みするか、次のように書くのがトラブルが少ないでしょう。

int n = Integer.parseInt(sc.nextLine());

そして、これに加えて終了条件にも問題があります。
Stringの配列とStringを比較してしまっているのです。

String[] strs = {"exit"};
System.out.println(strs.equals("exit"));   // false

同値かどうかではなく、包含されているかどうかを知る必要があります。
次のページが参考になるかもしれませんね。
Java入門 - 配列の要素に特定の値が含まれているかチェックする方法

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/02/08 01:30

    int n = Integer.parseInt(sc.nextLine());
    上記のコードだとNumberFormatExceptionが発生してしまいます。

    キャンセル

  • 2018/02/08 01:46

    どのような入力を想定しているのでしょうか?
    前もってexitあるいはquitのときはループを脱出して、そうでないときに整数にパースすればよいです。
    それでも例外が生じるのであれば、それは入力が不正であることを意味します。

    キャンセル

  • 2018/02/08 03:13

    解決しました!こんなにも丁寧にありがとうございました!

    キャンセル

checkベストアンサー

+1

質問文にはコンパイルエラーが発生しない最小限のソースコードを記載してくださいな。
Cst2.fbntとCst2.fbnが質問文のコードに存在しませんでした。

import java.util.Scanner;
import java.util.Set;
import java.util.stream.Collectors;
import java.util.stream.Stream;

public class Cst {

    public static void main(String[] args) {
        // 重複を許可しないなら、配列よりSetを使用するのがベター!
        Set<String> exit = Stream.of("exit", "quit").collect(Collectors.toSet());
        // try~with~Resources文を使う!
        try (Scanner sc = new Scanner(System.in)) {
            while (true) {
                String input = sc.nextLine();
                // 終了条件は最初に判定する。
                if (exit.contains(input)) {
                    System.out.println(input + "が入力されたので処理を終了します");
                    break;
                }
                // 数字に変換。NumberFormatExceptionのチェックもできればすること!
                int n = Integer.valueOf(input);
                if (n < 71) {
                    System.out.println(n + "番目のフィボナッチ数は:" + Cst2.fbnt(n));
                    System.out.println(n + "番目までのフィボナッチ数列は:" + Cst2.fbn(n));
                } else {
                    System.out.println("範囲外です");
                }
            }
        }
    }
}

class Cst2 {
    public static long fbnt(int n) {
        return n;
    }

    public static long fbn(int n) {
        return n;
    }
}

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/02/08 03:07

    ほんとにわかりやすかったです!!実際にコードのどのように動いているのか確認しながらやってみたら理解できました!!こんなにも丁寧でわかりやすく手間のかかる作業をありがとうございました!!

    キャンセル

  • 2018/02/08 03:26

    このコードでInputMismatchExceptionは発生しないのでは…

    キャンセル

  • 2018/02/08 03:30

    自分は発生しないようにしたかったので問題ないです。
    それ以前に質問文がややこしいせいで誤解を招いてしまって申し訳ないです<(_ _)>

    キャンセル

  • 2018/02/08 03:31

    >swordoneさんへ
    そうみたいですね。修正しておきますー。指摘ありがとうございましたー。

    キャンセル

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

  • ただいまの回答率 90.12%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる