题目:
你的笔记本键盘存在故障,每当你在上面输入字符 'i'
时,它会反转你所写的字符串。而输入其他字符则可以正常工作。
给你一个下标从 0 开始的字符串 s
,请你用故障键盘依次输入每个字符。
返回最终笔记本屏幕上输出的字符串。
思考:
创建一个结果字符串,初始为空。然后直接遍历原字符串,遇到非i的字符直接加到结果字符串末尾;遇到i字符,就反转结果字符串。
如何反转 Python 中的字符串?
切片语句 [::-1]
表示从字符串的末尾开始并在位置 0 结束,随着步骤 -1
,负一,表示后退一步。
代码如下:
class Solution(object):
def finalString(self, s):
"""
:type s: str
:rtype: str
"""
result = ''
for character in s:
if character == 'i': # 若字符为i则反转
result = result[::-1]
else: # 否则,在结果字符串最后加上该字符
result += character
return result
提交通过: