我正在寻找论坛,并找到了一个有用的代码,介绍如何计算输入字符串中的小写字母。事情是,在测试之后,我看到它只计算输入的第一个单词中的小写字母。所以,例如,如果我输入: HeRE ,计数器会说我输入了1个小写字母(这是正确的),但如果我输入: HeRE我计数器仍然只会说1而不是4.它只计算第一个单词中的小写字母。如何让它在整个字符串中计算小写字母?
到目前为止的代码:
import java.util.Scanner;
public class countingLowerCaseStrings {
public static void main(String args[]){
Scanner scanner = new Scanner(System.in);
System.out.println("Enter your string: ");
String input = scanner.next();
int LowerCaseLetterCounter = 0;
for (char ch : input.toCharArray()) {
if (Character.isLowerCase(ch)) {
LowerCaseLetterCounter++;
}
}
System.out.println ("Number of lower case letters in this string is: " +
LowerCaseLetterCounter);
}
}
非常感谢帮助!
答案 0 :(得分:3)
scanner.next();
读取第一个可用字词,而不是整行。
因此,如果你输入“Here i am”,它只会读作“HeRE”。
将其更改为scanner.nextLine()
:
System.out.println("Enter your string: ");
String input = scanner.nextLine();
DEMO - 查看stdin
和stdout
小组。
答案 1 :(得分:0)
感兴趣的是,Java 8提供了一种相当简化的方法来实现同样的目标:
scanner.nextLine().chars().filter(Character::isLowerCase).count()