Difficulty: 简单
给定一个字符串 s
和一个整数 k
,你需要对从字符串开头算起的每隔 2k
个字符的前 k
个字符进行反转。
k
个,则将剩余字符全部反转。2k
但大于或等于 k
个,则反转前 k
个字符,其余字符保持原样。示例:
输入: s = "abcdefg", k = 2
输出: "bacdfeg"
提示:
k
在 [1, 10000]
范围内。注意两个边界条件的控制:
2k
个字符的前 k
个字符进行反转,意味着第一个k间距反转,第二个k间距不反转,奇偶[i, min(i+k-1, len(s)-1)]
做反转class Solution:
def reverseStr(self, s: str, k: int) -> str:
l = list(s)
for i, _ in enumerate(l):
if (i / k) % 2 == 0:
l = self.reverse(l, i, min(i+k-1, len(s)-1))
else:
continue
return "".join(l)
def reverse(self, arr, start, end):
while start < end:
arr[start], arr[end] = arr[end], arr[start]
start += 1
end -= 1
return arr
原文:https://www.cnblogs.com/swordspoet/p/14586213.html