牛客网华为机试【计算字符串最后一个单词的长度,单词以空格隔开】

题目描述

计算字符串最后一个单词的长度,单词以空格隔开。

输入描述:
一行字符串,非空,长度小于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(" "));
        }
    }
}

结果

在这里插入图片描述

发布了108 篇原创文章 · 获赞 117 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/FBB360JAVA/article/details/104296082