题目:
计算字符串最后一个单词的长度,单词以空格隔开,字符串长度小于5000。(注:字符串末尾不以空格为结尾)
输入描述:
输入一行,代表要计算的字符串,非空,长度小于5000。
输出描述:
输出一个整数,表示输入字符串最后一个单词的长度。
分析:
输入一个字符串,字符串的结尾不是空格,中间或开头可能会出现空格,
那么测试用例可以考虑为:
1、空格XCD
2、空格CC空格vv
3、XCV
4、xcv空格CVF
一般用Scanner接收从控制台输入的数据,因为本题要求的是字符串,Scanner自带的方法接收后返回值是字符串的有两个,一个是next方法一个是nextLine方法。
二者区别:next从遇到的第一个有效字符开始扫描,到遇到第一个分隔符结束(空格或回车)
nextLine是扫描所有的字符串,遇到回车结束。
题目要求最后一个单词的长度,那么有两种思路。
一、字符串反向遍历,遇到第一个空格结束循环。如果此索引对应的不是空格,那么+1,是空格,结束循环。
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
int res=0;
for(int i =str.length()-1;i>-1;i--){
if(' '==str.charAt(i)){
break;
}
res++;
}
System.out.println(res);
二、将字符串以空格为分割标志,分割成数组。
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
String[] s = str.split(" ");
System.out.println(s[s.length-1].length());