LeetCode刷题-58.最后一个单词长度

bridge
2022-02-09 / 0 评论 / 0 点赞 / 1,702 阅读 / 769 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2022-02-09,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

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

一、题目

给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中最后一个单词的长度。

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

示例 1:

输入:s = "Hello World"
输出:5

示例 2:

输入:s = "   fly me   to   the moon  "
输出:4

示例 3:

输入:s = "luffy is still joyboy"
输出:6

提示:

  • 1 <= s.length <= 10^4
  • s 仅有英文字母和空格 ' ' 组成
  • s 中至少存在一个单词

二、题解

解题源码: 链接

\时间复杂度空间复杂度
反向遍历O(n)O(1)

2.1.拷贝覆盖

2.1.1.算法步骤

  • 从右向左遍历,从第一个不是空格的字符开始计数,一旦开始计数,再遇到空格就结束了

2.1.2.动画演示

2.1.3.复杂度分析

  • 时间复杂度:O(n),其中 n 是字符串的长度。最多需要反向遍历字符串一次。
  • 空间复杂度:O(1)。

2.1.4.参考代码

解题源码: 链接

public class Id_0058_ReverseTraverse implements Id_0058 {

    @Override
    public int lengthOfLastWord(String s) {
        char[] chars = s.toCharArray();
        int count = 0;
        for (int i = chars.length - 1; i >= 0; i--) {
            if (chars[i] == ' ') {
                if (count > 0) break;
                continue;
            }
            count++;
        }
        return count;
    }

}

以上是个人学习记录,如有不正确请多多包涵,也欢迎评论告诉我,谢谢~


0

评论区