当前位置: 首页 > news >正文

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--;}}
};

特点

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

题目二: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--;
}
  1. 分段反转模板
for (int i = 0; i < n; i += 2*k) {reverse(s, i, min(i + k, n));
}
http://www.dtcms.com/a/601369.html

相关文章:

  • 【代码审计】RuoYi-4.7.34.7.8 定时任务RCE 漏洞分析
  • 数学图论的艺术:解码最小公倍数图中的连通奥秘
  • 如何有效解决Windows 11界面卡顿问题,提升操作流畅度
  • 网站开发iso9001有哪些网页游戏网站
  • nginx安装配置、故障处置、性能优化
  • 网上商城互联网网站开发网站建设流程效果
  • 商品案例-组件封装(vue)
  • 新视角看 js 的数据类型
  • PySide6 + QML - QSerialPort01 - 扫描操作系统上有效的串口
  • 【前端面试】HTML篇
  • Next.js第四章(路由导航)
  • 从jsp打开一个html,怎么把jsp的某些参数传递给html
  • 谷歌google官方网站网站开发 书籍
  • 北京网站备案公司安徽观元建设有限公司网站
  • 若依plus请求加解密
  • PHP Filter:深入了解其功能与实现
  • Linux基础指令(简易版)
  • 农田灌区监测设备:赋能现代农业的精准感知与智能调控
  • 中山 灯饰 骏域网站建设专家百度关键词推广帝搜软件
  • 自己怎么做 优惠券网站西京一师一优课建设网站
  • CST电动车EMC仿真(二)——电机控制器MCU的EMC仿真
  • WPP Media(群邑)DOOH 解决方案 重构数字户外广告价值
  • 基于SpringBoot+Vue的美容美发在线预约系统的设计与实现【附源码】
  • 数字化转型改变了什么?从技术底层到业务本质的深度重构
  • 从 “被动抢修” 到 “主动防控”,安科瑞 mini 智能微断,重构末端配电安全新逻辑
  • 从经验到算法:智能获客系统如何重构ToB销售效率
  • Oracle 19C 数据字典 DBA_HIST_SEG_STAT 详细说明
  • tsfile.raw提示
  • JAVA中六种策略模式的实现
  • 【ZeroRange WebRTC】TLS 底层原理与工作机制(深入解析)