• [ LeetCode ] 题刷刷(Python)-第58题:最后一个单词的长度


    题目描述

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

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

    示例

    示例 1:

    输入:s = "Hello World"
    输出:5
    解释:最后一个单词是“World”,长度为5。
    示例 2:

    输入:s = "   fly me   to   the moon  "
    输出:4
    解释:最后一个单词是“moon”,长度为4。
    示例 3:

    输入:s = "luffy is still joyboy"
    输出:6
    解释:最后一个单词是长度为6的“joyboy”。

    解题

    解法一:反向遍历

    思路

    使用 strip() 方法去除字符串首尾的空白字符,如字符串末尾有额外空格。

    从字符串末尾开始遍历,通过计数连续的非空格字符来确定最后一个单词的长度。一旦遇到空格,立即停止计数并返回当前计数值作为结果。

    算法复杂度

    时间复杂度:O(n),其中 n是字符串s的长度。


    空间复杂度:O(1)。

    代码

    1. class Solution:
    2. def lengthOfLastWord(self, s: str) -> int:
    3. # 去除字符串首尾的空白字符
    4. s = s.strip()
    5. # 从字符串末尾开始
    6. i = len(s) - 1
    7. # 用于记录最后一个单词的长度
    8. count = 0
    9. while i >= 0:
    10. # 如果当前字符不是空格
    11. if s[i] != ' ':
    12. count += 1
    13. else:
    14. break
    15. i -= 1
    16. return count

    解法二:将字符串分割成单词列表

    思路

    使用 strip() 方法去除字符串首尾的空白字符,如字符串末尾有额外空格。使用空格作为分隔符,将字符串分割成单词列表,最后返回列表中最后一个单词的长度。

    算法复杂度

    时间复杂度:O(n),其中 n是字符串s的长度。


    空间复杂度:O(n),其中 n是字符串s的长度。

    split() 方法会生成一个新的列表 words 存放分割后的单词。在最坏情况下,假设字符串没有空格,即所有字符都是单词的一部分,那么 words 列表将包含 n 个元素,每个元素对应一个单字符的单词。

    代码

    1. class Solution:
    2. def lengthOfLastWord(self, s: str) -> int:
    3. # 移除字符串首尾的空白字符
    4. s = s.strip()
    5. # 使用空格作为分隔符,将字符串分割成单词列表
    6. words = s.split()
    7. # 返回列表中最后一个单词的长度
    8. return len(words[-1])
  • 相关阅读:
    GBase 8c V3.0.0数据类型——时间/日期函数
    git 新手教程
    【iOS逆向与安全】插件开发之某音App直播间自动发666
    MNN介绍、安装和编译(Linux)
    【AI视野·今日NLP 自然语言处理论文速览 第三十八期】Thu, 21 Sep 2023
    【echarts】解决ECharts鼠标悬停(mouseover)事件触发范围问题
    【MySQL】查询语句
    ERR_FAILED 200 解决方案
    工厂模式(Factory Pattern)
    在C#中,如何以编程的方式设置 Excel 单元格样式
  • 原文地址:https://blog.csdn.net/zhou_ge1/article/details/138015170