题目:反转字符串中的单词 III
给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。
示例 :
输入: "Let's take LeetCode contest"
输出: "s'teL ekat edoCteeL tsetnoc"
注意:在字符串中,每个单词由单个空格分隔,并且字符串中不会有任何额外的空格。
----------------------------------------------------
解法1:将字符串s转换为数组li,对li中每个string进行反转处理,再拼接成字符串返回即可。
join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串
join()方法语法:str.join(sequence)
class Solution(object):
def reverseWords2(self, s):
"""
:type s: str
:rtype: str
"""
li = s.split(" ")
li2 = [str[::-1] for str in li]
return " ".join(li2)
解法2:使用正则表达式匹配出每个单词.
findall() 在字符串中找到正则表达式所匹配的所有子串,并返回一个列表,如果没有找到匹配的,则返回空列表。
注意: match 和 search 是匹配一次 findall 匹配所有。
class Solution(object):
def reverseWords2(self, s):
"""
:type s: str
:rtype: str
"""
# 正则表达式
import re
# findall匹配出所有字母或’组成的结果,返回数组
matchObj = re.findall(r'[\w\']+', s) # 注意’需要用转义字符\来处理。
return " ".join([str[::-1] for str in matchObj])
参考: