模拟-反转字符串2

本文介绍了一种处理字符串反转问题的算法,通过每2k个字符为一段进行反转,同时提供了Python3和C++版本的代码实现,并分析了这两种实现的时间和空间复杂度。
摘要由CSDN通过智能技术生成

Problem: 541. 反转字符串 II

文章目录

思路

模拟,以每2k个字符作为一段,反转其中前k个字符, 正好python列表若索引超出最长,则一直取到最长,进行前k个字符选择时可通过这个trick,保证小于k长度的最后一段被全部反转

复杂度

时间复杂度:

O ( n ) O(n) O(n)

空间复杂度:

O ( n ) O(n) O(n)

Code

Python 3版本代码

class Solution:
    def reverseStr(self, s: str, k: int) -> str:
        def swapk(res):
            n = len(res)
            for j in range(n//2):
                res[j], res[n-j-1] = res[n-j-1], res[j]
            return res
        n = len(s)
        res = list(s)

        for i in range(0, n, 2*k):
            res[i: i + k] = swapk(res[i: i + k])
        return ''.join(res)

C++ 版本代码

class Solution {
public:
    string reverseStr(string s, int k) {
        int len = s.size();
        for (int i=0; i<len; i += 2*k  ){
            if(i +k <s.size()){
                reverse(s.begin() + i, s.begin() + i + k);
            }
            else{
                reverse(s.begin()+i, s.begin()+s.size());
            }
            
        }
        return s;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值