在做网易2017年机试题——两种排序方法时,出现使用nextInt()后nextLine()读不了字符串的问题。
该题目如下:
题目描述
考拉有n个字符串字符串,任意两个字符串长度都是不同的。考拉最近学习到有两种字符串的排序方法: 1.根据字符串的字典序排序。例如:
"car" < "carriage" < "cats" < "doggies < "koala"
2.根据字符串的长度排序。例如:
"car" < "cats" < "koala" < "doggies" < "carriage"
考拉想知道自己的这些字符串排列顺序是否满足这两种排序方法,考拉要忙着吃树叶,所以需要你来帮忙验证。
"car" < "carriage" < "cats" < "doggies < "koala"
2.根据字符串的长度排序。例如:
"car" < "cats" < "koala" < "doggies" < "carriage"
考拉想知道自己的这些字符串排列顺序是否满足这两种排序方法,考拉要忙着吃树叶,所以需要你来帮忙验证。
输入描述:
输入第一行为字符串个数n(n ≤ 100) 接下来的n行,每行一个字符串,字符串长度均小于100,均由小写字母组成
输出描述:
如果这些字符串是根据字典序排列而不是根据长度排列输出"lexicographically", 如果根据长度排列而不是字典序排列输出"lengths", 如果两种方式都符合输出"both",否则输出"none"
我的代码:
import java.util.Scanner;
public class Main{
public static void main(String args[]){
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
int n = sc.nextInt();
boolean dic = true;
boolean seq = true;
// sc.nextLine();
String upString = sc.nextLine();
for(int i=1;i<n;i++){
String temp = sc.nextLine();
if(temp.compareToIgnoreCase(upString) <= 0)
dic = false;
if(temp.length() <= upString.length())
seq = false;
upString = temp;
}
if(dic == true && seq == true)
System.out.println("both");
else if(dic == true && seq == false)
System.out.println("lexicographically");
else if (dic == false && seq == true)
System.out.println("lengths");
else {
System.out.println("none");
}
}
}
}
再这个混过去,于是查找了一下原因。其原因如下:
nextInt()方法在读取数字时,不会将转义字符读进去,因此换行字符就留在了输入缓冲区上,而nextLine()方法是以换行字符为结束符将数据与结束符读入。所以就会出现在nextInt()方法后的nextLine()读入的是空字符串。
针对这个问题,有两种方法解决:
1.在nextInt()和nextLine()中间加入一个nextLine()。
2.都使用nextLine()进行读取,在读取整数时采用Integer类的parseInt()方法转换成整数。
参考资料:
Blog:http://blog.youkuaiyun.com/wjy1090233191/article/details/42080029