美文网首页
LeetCode 每日一题 [26] 最后一个单词的长度

LeetCode 每日一题 [26] 最后一个单词的长度

作者: 是小猪童鞋啦 | 来源:发表于2020-06-13 08:08 被阅读0次
LeetCode 最后一个单词的长度 [简单]

给定一个仅包含大小写字母和空格 ' ' 的字符串 s,返回其最后一个单词的长度。如果字符串从左向右滚动显示,那么最后一个单词就是最后出现的单词。

如果不存在最后一个单词,请返回 0 。

说明:一个单词是指仅由字母组成、不包含任何空格字符的 最大子字符串。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/length-of-last-word

示例:

输入: "Hello World"
输出: 5

题目分析
方法1:

首先判断字符串是否合格,然后使用 String[] res = s.split(" "); 分割,然后返回数组最后的一个元素的长度

方法2:

首先判断字符串是否合格,去掉两边的空格,然后从后向前面遍历,直到遇到 ' ' ,否则 res 一直自增

代码实现
public class LeetCode_26_LengthOfLastWord {
    public static void main(String[] args) {
        System.out.println(lengthOfLastWord("Hello World"));
        System.out.println(lengthOfLastWord2("Hello World"));
    }


    public static int lengthOfLastWord2(String s) {
        if (s == null || "".equals(s) || "".equals(s.trim())) {
            return 0;
        }
        s = s.trim();
        int res = 0;
        for (int i = s.length() - 1; i >= 0; i--) {
            if (s.charAt(i) == ' ') {
                return res;
            }
            res++;
        }
        return res;
    }

    public static int lengthOfLastWord(String s) {
        if (s == null || "".equals(s) || "".equals(s.trim())) {
            return 0;
        }
        String[] res = s.split(" ");
        return res[res.length - 1].length();
    }
}

相关文章

网友评论

      本文标题:LeetCode 每日一题 [26] 最后一个单词的长度

      本文链接:https://www.haomeiwen.com/subject/mhykohtx.html