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 的修改会直接反映到原始字符串上。

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

相关推荐
FQNmxDG4S7 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
超级码力6667 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑7 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind7 小时前
HashMap详解
算法·哈希算法·散列表
虹科网络安全7 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje8 小时前
Java语法进阶
java·开发语言·jvm
汉克老师8 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
rKWP8gKv78 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫8 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287928 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日