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

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

相关推荐
灰色人生qwer6 分钟前
SpringBoot项目注入 traceId 来追踪整个请求的日志链路
java·spring boot·后端·日志·slf4j·链路追踪
我命由我1234523 分钟前
34.Java 阻塞队列(阻塞队列架构、阻塞队列分类、阻塞队列核心方法)
java·服务器·开发语言·后端·架构·java-ee·后端开发
猿周LV27 分钟前
JUC (java. util.concurrent) 的常见类及创建新线程的方法等 [Java EE 初阶]
java·开发语言·java-ee
CN.LG28 分钟前
Spring Boot 与@Bean注解搭配场景
java·spring boot·spring
HPF_9932 分钟前
JVM 简单内存结构及例子
java·jvm
m0_7482489434 分钟前
猿创征文 【高级篇】Java 进阶之JVM实战
java·开发语言·jvm
WLKQ36 分钟前
力扣——完全平方数
算法·leetcode·职场和发展
计算机毕设指导639 分钟前
基于Springboot的小说网站【附源码】
java·开发语言·spring boot·后端·mysql·spring·maven
xxxmmc1 小时前
Leetcode 141 Linked List Cycle and Leetcode 142 Linked List Cycle II
算法·leetcode·快慢指针
盖世英雄酱581361 小时前
延迟5个月的回复:编程式事务的传播行为存在并发问题?
java·后端