11.12 LeetCode 题目汇总与解题思路

题目一:344. 反转字符串

解法1:单指针法

复制代码
class Solution {
public:
    void reverseString(vector<char>& s) {
        int n = s.size();
        if (n < 2) return;
        int left = 0;
        while (left < n / 2) {
            char tmp = s[left];
            s[left] = s[n - left - 1];
            s[n - left - 1] = tmp;
            left++;
        }
    }
};

特点

  • 使用单个指针 left
  • 通过 n - left - 1 计算对称位置
  • 遍历到数组中间即可

解法2:双指针法(更直观)

复制代码
class Solution {
public:
    void reverseString(vector<char>& s) {
        if (s.size() < 2) return;
        int left = 0, right = s.size() - 1;
        while (left < right) {
            char tmp = s[left];
            s[left] = s[right];
            s[right] = tmp;
            left++;
            right--;
        }
    }
};

特点

  • 使用双指针 leftright
  • 逻辑更清晰直观
  • 交换直到指针相遇

题目二:541. 反转字符串 II

解法:分段反转

复制代码
class Solution {
public:
    string reverseStr(string s, int k) {
        for (int i = 0; i < s.size(); i += (k * 2)) {
            // 需要反转的区间: [i, i+k-1]
            if (i + k <= s.size()) {
                reverse(s.begin() + i, s.begin() + i + k);  // 反转前k个
                continue;
            }
            reverse(s.begin() + i, s.end());   // 剩余不足k个,全部反转
        }
        return s;
    }
};

算法思路详解

反转字符串 II 的执行逻辑:

复制代码
输入: s = "abcdefg", k = 2

分段处理:
i=0: 反转[0,1] → "bacdefg"
i=4: 反转[4,5] → "bacdfeg" 
i=8: 超出范围,结束

结果: "bacdfeg"

规则总结

  • 2k 个字符为一组
  • 每组反转前 k 个字符
  • 剩余字符少于 k 个时,全部反转

核心技巧对比

技巧 适用场景 时间复杂度 空间复杂度
单指针 简单反转、对称操作 O(n) O(1)
双指针 双向遍历、交换操作 O(n) O(1)
分段反转 固定间隔反转 O(n) O(1)

关键优化点

反转字符串的交换优化:

复制代码
// 更简洁的交换写法
swap(s[left], s[right]);

// 或者使用异或交换(不推荐,可读性差)
s[left] ^= s[right];
s[right] ^= s[left]; 
s[left] ^= s[right];

反转字符串 II 的边界处理:

复制代码
// 更简洁的写法
for (int i = 0; i < s.length(); i += 2 * k) {
    int end = min(i + k, (int)s.length());
    reverse(s.begin() + i, s.begin() + end);
}

扩展应用

自定义反转函数:

复制代码
void myReverse(vector<char>& s, int start, int end) {
    while (start < end) {
        swap(s[start], s[end]);
        start++;
        end--;
    }
}

// 在反转字符串II中使用
if (i + k <= s.size()) {
    myReverse(s, i, i + k - 1);
}

性能分析

反转字符串

  • 两种解法性能相同
  • 双指针法更易理解和维护

反转字符串 II

  • 关键在正确的区间计算
  • 注意边界条件的处理

记忆要点

  1. 双指针模板

    int left = 0, right = n - 1;
    while (left < right) {
    swap(s[left], s[right]);
    left++; right--;
    }

  2. 分段反转模板

    for (int i = 0; i < n; i += 2*k) {
    reverse(s, i, min(i + k, n));
    }

相关推荐
深邃-1 小时前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
We་ct4 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
王老师青少年编程8 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮9 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说9 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove10 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung10 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了10 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL11 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰11 小时前
C++ 排列组合完整指南
开发语言·c++·算法