给定一个字符串 s 和一个整数 k,你需要对从字符串开头算起的每隔 2k 个字符的前 k 个字符进行反转。
如果剩余字符少于 k 个,则将剩余字符全部反转。
如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/reverse-string-ii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution: def reverseStr(self, s: str, k: int) -> str: left, mid, right = 0, k, 2 * k # 初始化左中右指针 res = '' # 初始化结果字符串 while len(res) < len(s): # 满足条件时执行 res += s[left:mid][::-1] + s[mid:right] # 把当前单元的结果添加到结果字符串 left, mid, right = left + 2 * k, mid + 2 * k, right + 2 * k return res