牛客网华为机试【计算字符串最后一个单词的长度,单词以空格隔开】
程序员文章站
2022-03-04 18:40:22
...
题目描述
计算字符串最后一个单词的长度,单词以空格隔开。
输入描述:
一行字符串,非空,长度小于5000。
输出描述:
整数N,最后一个单词的长度。
示例
输入
hello world
输出
5
题目分析
首先,是接收一个字符串,需要找出最后一个空格字符串出现的位置!
如此一来,使用 String
类的 lastIndexof()
方法。
该方法的作用是 返回指定的子字符串的最后一次出现在该字符串中的索引 。当找不到目标时,返回值为 -1
。
那么计算时,找出最后一次空格出现的位置,使用总的字符串长度减去它,问题来了,在计算索引时,是从0开始的,因此还要再减去1。
因此,总字符串长度 - 1 - 空格字符串最后出现位置 = 最后一个单词的长度
使用 “hello world”
作为例子,总的长度是11,空格字符最后出现的位置是 5,所以 11 -5 -1 就是最后一个单词的长度。
再比如, “hello"
这个字符串没有空格,那么找了之后,返回值是 -1,字符串总长度是 5,那么最后一个单词就是其本身,所以 5 - 1 - (-1) = 5
java 代码
public class Main {
public static void main(String[] args) {
java.util.Scanner input = new java.util.Scanner(System.in);
while(input.hasNextLine()){
// 输入一行
String item = input.nextLine();
System.out.println(item.length() - 1 - item.lastIndexOf(" "));
}
}
}