更好的方法来替换不必要的 scan.nextLine();找到 StdIn 字符串?

问题描述 投票:0回答:6

我一直在解决 HackerRank 问题,并在向任何社区寻求帮助之前始终尝试研究解决方案。虽然我设法让当前的代码正常工作,但我觉得其中涉及一些不必要的代码,并且有人可以教我如何做得更好,因为我不想仅仅因为它有效就养成一个坏习惯。

在本课 HackRank 30 天代码(第 2 天)中,我们被要求从 Stdin 读取 3 行(一个 Int、一个 Double 和一个 String),并使用扫描仪读取它们、保存它们并操作它们。

    Scanner scan = new Scanner(System.in);

    /* Declare second integer, double, and String variables. */
    int myI = scan.nextInt();
    double myDouble = scan.nextDouble();
    scan.nextLine();
    String myString = scan.nextLine();

扫描 Int 和 Double 很容易,但是当我尝试扫描 String 时遇到了一些问题:

A) 如果我使用 scan.next();我返回的是一个单词而不是完整的字符串。

B) 如果我使用 scan.nextLine();我得到了一个空行。

经过一番研究,我发现有人建议这样做,因为我刚刚做了 scan.nextDouble();扫描.nextLine();只是简单地读取该行末尾的空白(这对我来说没有多大意义),并且如果我添加额外的“scan.nextLine();”在声明我的字符串之前它应该可以工作。

果然如此。我真的不明白为什么,而且肯定感觉这不是解决这个问题的正确方法。看来如果我必须频繁这样做,只会使代码变得臃肿?

任何人都可以透露一些信息吗:

1) 为什么使用 scan.nextLine();返回空白,直到我添加一个额外的?

2)有没有更好的方法从扫描中定位字符串?

java string java.util.scanner stdin
6个回答
1
投票

scan.nextLine() 返回下一个新行分隔符之前的所有内容,或者 .

所以,我假设输入看起来像这样:

1 2.5
whatever

所以,这个字符串实际上在第一行和第二行之间有一个下一行分隔符。之前,当您没有额外的 nextLine() 时,您的字符串会被分配给一个空字符串,因为它正在消耗下一行分隔符。

额外的 nextLine() 消耗了不需要的下一行分隔符,因此您的字符串可以分配给您想要的内容。


1
投票

要以更少的行编写代码,您可以在同一行中读取换行符并解析 myDouble。

    int myI = scan.nextInt();
    double myDouble = Double.parseDouble(scan.nextLine());
    String myString = scan.nextLine();

0
投票

scan.nextLine();
为什么会有这个?我想这就是它搞砸的原因。
我也是这样学会的。

    System.out.println("Enter String");
    String string = read.nextLine();  

0
投票

很明显,如果您紧随

nextLine()
方法使用
nextInt()
方法,则将显示 blank/empty。这是因为
nextInt()
读取整数标记,因此该行的最后一个 newline 字符(整数输入)仍在输入缓冲区中排队。
这最终会欺骗下一个
nextLine()
,最后它将读取整数行的剩余部分,该行是空的。

因此,据我对 Stdin 的了解,如果您在接受整数/双精度/浮点数后必须接受字符串输入,那么您必须使用虚拟

nextLine()
;欺骗输出。


0
投票

简单兄弟只使用 scan.next()


0
投票

下面的代码片段会有帮助:

    int i = scan.nextInt();
    double d = scan.nextDouble();
    String s = scan.nextLine();
    s = scan.nextLine();`
© www.soinside.com 2019 - 2024. All rights reserved.