原题:
给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。
示例:
输入:"Let's take LeetCode contest"
输出:"s'teL ekat edoCteeL tsetnoc"
解题思路
总的思路是:
(1)先反转单词,再反转全部
(2)主要用到 join() 函数和split函数,join()函数用于将字符串组合,split()函数将字符串分割,返回分割后的列表。
(3)反转列表、字符串最常用的:[::-1],其结果直接将列表的元素顺序反转,将字符串的字符顺序反转。示例:
b='love'
b[::-1]
out:'evol'
a='i love u'
b=a.split()
print(b)
print(b[::-1])
out:
['i', 'love', 'u']
['u', 'love', 'i']
题目代码
class Solution:
def reverseWords(self, s: str) -> str:
s=s.split()
return ' '.join(s[::-1])[::-1]
join()函数:
语法: ‘sep’.join(seq)
参数说明
**sep:**分隔符。可以为空
**seq:**要连接的元素序列、字符串、元组、字典
上面的语法即:以sep作为分隔符,将seq所有的元素合并成一个新的字符串
**返回值:**返回一个以分隔符sep连接各个元素后生成的字符串
a='i love u'
b=a.split()
c=' '.join(b)
d=' '.join(b[::-1])
f=d[::-1]
print(b)
print(c)
print(b[::-1])
print(d)
print(f)
out:
['i', 'love', 'u']
i love u
['u', 'love', 'i']
u love i
i evol u