今天刷力扣字符串,原题如下:
给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。
示例 1:
输入: "Let's take LeetCode contest"
输出: "s'teL ekat edoCteeL tsetnoc"
注意:在字符串中,每个单词由单个空格分隔,并且字符串中不会有任何额外的空格。
非常简单的思路,用字符串自带函数split分割字符串,之后 ,再用[::-1]操作逐个翻转列表中每个单词即可
最开始代码如下
def reverseWords( s: str) -> str:
sl = s.split()
for x in sl:
x= x[::-1]
return " ".join(sl)
S="Let's take LeetCode contest"
print(reverseWords(S))输出如下:

然后,我怀疑x不是字符串了?于是又去控制台看了看

那么答案出现了,那就是在for 中直接用值进行运算时,结果并没有保存进原列表中,x应该是相当于一个拷贝值,所以要选对原字符串操作,还是得用下标。修改之后 的代码如下:
def reverseWords(self, s: str) -> str:
s=s.split()
for i in range(len(s)):
s[i]=s[i][::-1]
return " ".join(s)
S="Let's take LeetCode contest"
print(reverseWords(S))结果如下 :

版权声明:本文为weixin_32693561原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。