leetcode541 反转字符串2

1.我的笨思路:计算有几组完整的2k,循环交换,计算完整2k之外剩余几个元素,与k、2k不同关系下不同的处理剩余元素。

当然可以将交换过程封装成一个函数。

cpp 复制代码
class Solution {
public:
    string reverseStr(string s, int k) {
        int n = s.size();
        int num = n / (2*k);
        int res = n % (2*k);
        for(int i=0; i < num; i++){
            for(int left = i*(2*k), right = k + i*(2*k)-1; left < right; left++, right--){
                swap(s[left], s[right]);
            }               
        }
        if(res > 0 && res < k){
            for(int left = num*2*k, right = n-1; left < right; left++, right--){
                swap(s[left], s[right]);
            }
        }
        if(res >= k && res < 2*k){
            for(int left = num*2*k, right = num*2*k + k - 1; left < right; left++, right--){
                swap(s[left], s[right]);
            }
        }
        return s;
    }
};

2.从头开始,如果未来k个还都在字符串中,就将当前到当前后面k个进行反转,退出本轮循环,i+2k.如果未来k个已经超出字符串,即剩余不足k个(到了结尾),就将剩余的所有反转即可。

cpp 复制代码
class Solution{
    public:
    void reverse(string& s, int star, int end){
        for(int i = star, j = end; i < j ; i++, j--){
            swap(s[i], s[j]);
        }
    }

    string reverseStr(string s, int k){
        int n = s.size();
        for(int i = 0; i < n; i += 2*k){
            if(i + k <= n){
                reverse(s, i, i + k - 1);
                continue;
            }
            reverse(s, i, n - 1);
        }
        return s;
    }
};

其中

为什么使用 string& s

  1. 避免拷贝

    • 如果参数是 string s(而不是 string& s),那么在调用 reverse 函数时,会创建一个新的 string 对象,并将原始字符串的内容复制到新对象中。

    • 对于大字符串,这种拷贝操作会消耗额外的时间和内存。

    • 使用 string& s 可以避免拷贝,直接操作原始字符串。

  2. 修改原始字符串

    • 由于 s 是引用,函数内部对 s 的修改会直接反映到原始字符串上。

    • 如果你希望函数修改传入的字符串,必须使用引用或指针。

相关推荐
Emberone17 小时前
排序:万物皆有序
算法·排序算法
其实秋天的枫17 小时前
2025年12月英语六级真题及答案解析完整版(第一、二、三套全PDF)
经验分享·算法
有一个好名字17 小时前
vibe codeing 开发流程
java
2401_8747325317 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
2301_7923082517 小时前
C++编译期数学计算
开发语言·c++·算法
hetao173383717 小时前
2025-03-13~22 hetao1733837 的刷题记录
c++·算法
兑生18 小时前
【灵神题单·贪心】3745. 三元素表达式的最大值 | 排序贪心 | Java
java·开发语言
polaris063018 小时前
Windows操作系统部署Tomcat详细讲解
java·windows·tomcat
sqyno1sky18 小时前
C++中的契约编程
开发语言·c++·算法
优化控制仿真模型18 小时前
2026年最新驾考科目一考试题库2309道全。电子版pdf
经验分享·算法·pdf