输入一句话(如:ni, hao. wo),将其中的所有单词都输出出来。
1.使用String的split方法
Scanner scanner = new Scanner(System.in);
String in = scanner.nextLine();
String[] words = in.split("\\b");
for (int i = 0; i < words.length; i++) {
System.out.println(words[i]);
}
\b用来匹配单词边界,一定要注意:split方法会将所有的边界(如. " " )都保存在返回的数组中。其他的分隔符如split(",")中的逗号,不会保存在数组中。输出结果如下:
若要满足题目的要求,还要对数组中的每个String进行判断。
2.使用Matcher中的find()方法
Scanner scanner = new Scanner(System.in);
String in = scanner.nextLine();
Pattern pattern = Pattern.compile("[\\w]+");
Matcher matcher = pattern.matcher(in);
while (matcher.find()) {
System.out.println(in.substring(matcher.start(), matcher.end()));
}
Matcher中有三个方法方法需要注意。matches find lookingAt
matches()方法永远匹配的时整个字符串
find()是找子串,若在使用find()前使用了matches(),则有可能对find()的结果产生影响,matchers前面吃进去的不会吐出来,所以一般需要reset()一下(使前面吃进去的吐出来)。当find()方法找到的时候,可以使用start()、end()方法返回子串在原字符串中的开始和结束位置,end()是匹配子串最后一个字符的下一个位置。
lookingAt()方法每次都是从头找是否有匹配的子串。
上面程序运行的结果: