题目
问题描述:
给你一个字符串S,请你“反转”字符串中单词的顺序。
单词是由非空字符组成的字符串。
S中使用至少一个空格将字符串中的单词分隔开。
返回“单词顺序颠倒”且单词之间用“单个空格”连接结果字符串。
注意:
输入字符串S中可能会存在前导空格、尾随空格或者单词间的多个空格。
解答
多种实现方式。
'''问题描述:
给你一个字符串S,请你“反转”字符串中单词的顺序。
单词是由非空字符组成的字符串。
S中使用至少一个空格将字符串中的单词分隔开。
返回“单词顺序颠倒”且单词之间用“单个空格”连接结果字符串。
注意:
输入字符串S中可能会存在前导空格、尾随空格或者单词间的多个空格。
'''
'''示例:
输入1:"the sky is blue"; 输出:"blue is sky the"
输入2:" hello world "; 输出:"world hello"
输入3:"a good example"; 输出:"example good a"
'''
'''方法一:定义函数'''
def reverseWords1(s: str) -> str:
# 使用strip()方法,去除前导空格和尾随空格
s = s.strip()
# 反转单词顺序
words = s.split()
words.reverse()
# 连接单词
return " ".join(words)
# 测试函数
if __name__ == '__main__':
print("方法一:")
print(reverseWords1("the sky is blue")) # "blue is sky the"
print(reverseWords1(" hello world ")) # "world hello"
print(reverseWords1("a good example")) # "example good a"
'''
#⚠️注意:使用split()方法后,返回的是一个列表
'''
'''方法二:列表解析式'''
def reverseWords2(s: str) -> str:
# 使用strip()方法,去除前导空格和尾随空格
s = s.strip()
# 找出单词,并反转单词顺序
words = s.split()
words = words[::-1]
# 连接单词
return " ".join(words)
# 测试函数
if __name__ == '__main__':
print("方法二:")
print(reverseWords2("the sky is blue")) # "blue is sky the"
print(reverseWords2(" hello world ")) # "world hello"
print(reverseWords2("a good example")) # "example good a"
'''方法三:最基本的使用for循环'''
def reverseWords2(s: str) -> str:
# 使用strip()方法,去除前导空格和尾随空格
s = s.strip()
# 找到单词,以空格为分隔符,将字符串分割为列表
s = s.split()
words = [] # 用来存储单词
for i in range(len(s)-1, -1, -1):
words.append(s[i])
# 连接单词
return " ".join(words)
# 测试函数
if __name__ == '__main__':
print("方法三:")
print(reverseWords2("the sky is blue")) # "blue is sky the"
print(reverseWords2(" hello world ")) # "world hello"
print(reverseWords2("a good example")) # "example good a"