【题目】
给你一个字符串 s,由若干单词组成,单词之间用空格隔开。返回字符串中最后一个单词的长度。如果不存在最后一个单词,请返回 0 。
单词 是指仅由字母组成、不包含任何空格字符的最大子字符串。
【示例 1】
输入:s = “Hello World”
输出:5
【示例 2】
输入:s = " "
输出:0
【提示】
1 <= s.length <= 104
s 仅有英文字母和空格 ’ ’ 组成
【代码】
【Python-split()函数】
class Solution:
def lengthOfLastWord(self, s: str) -> int:
l=[x for x in s.split(" ") if len(x)]
if len(l)==0:
return 0
return len(l[-1])
【Python-方法2】
从后往前查找最后一个单词,用end记录遇到的第一个非空格字符所在的位置,当记录end之后再次碰到空格的时候就是这个单词开始的前一个位置,二者之差就是最后一个单词的长度
class Solution:
def lengthOfLastWord(self, s: str) -> int:
s=" "+s
l=len(s)
end=-1
flag=1
for i in range(l-1,-1,-1):
if s[i]!=' ' and flag:
end=i
flag=0
elif s[i]==' ' and not flag:
return end-i
return 0