来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/length-of-last-word
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
给你一个字符串 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”。
(1)
自己的想法
逆序判断字符是否是空格,不是空格头插入一个新列表。所以运行空间占用大。
class Solution:
def lengthOfLastWord(self, s: str) -> int:
k = -1
c = []
for i in range(len(s)):
if s[k - i] != ' ':
print(s[k - i])
c.insert(0, s[k - i])
elif len(c) == 0:
continue
else:
break
return len(c)
aaa=Solution()
print(aaa.lengthOfLastWord(s))
(2)
链接:https://leetcode-cn.com/problems/length-of-last-word/solution/by-zagiee-uuf8/
一行解决的骚操作。
class Solution:
def lengthOfLastWord(self, s: str) -> int:
return len(s.split( )[-1])
(3)
链接:https://leetcode-cn.com/problems/length-of-last-word/solution/pyh-by-strange-vvilesram-ofdn/
为什么快呢?
class Solution(object):
def lengthOfLastWord(self, s):
i = 0
num = 0
str = s[-1::-1]
while i<len(str):
if str[i] != ' ':
num+=1
if num>0 and str[i] == ' ':#应对开始就为空格的情况
break
i+=1
return num