【算法复习】数组与双指针篇

一、快慢指针(同向指针)

1. 核心概念

两个指针 fastslow 从同一侧(通常是索引 0)出发。

  • 快指针 fast 像侦察兵,负责在前面遍历整个数组,寻找符合「保留」条件的元素。
  • 慢指针 slow 像后勤兵,停在需要被替换的位置,只在接收到快指针传来的有效数据时才往前走。

2. 关键词

  • 「原地」修改 / 删除 / 去重
  • 「移动特定元素到末尾」(如移动 0)
  • 核心诉求:需要在 O(n)O(n)O(n) 时间复杂度和 O(1)O(1)O(1) 空间复杂度下完成数组元素的重排。

3. 代码模板

jsx 复制代码
// 适用场景:把所有符合条件的元素移到前面
let slow = 0;
for (let fast = 0; fast < nums.length; fast++) {
    if (/* nums[fast] 是我们需要保留的元素 */) {
        // 1. 赋值或交换
        nums[slow] = nums[fast];
        // 2. 慢指针前进一步,准备接收下一个
        slow++;
    }
}
// 循环结束后,slow 的值通常就是处理后新数组的长度

练习题目: LeetCode 27(移除元素)、LeetCode 283(移动零)

二、左右指针(对撞指针)

1. 核心概念

两个指针从数组的两端出发,left 在头,right 在尾,相向而行,直到相遇或交错。

2. 关键词

  • 「有序数组」+「两数之和 / 查找」(这是最强烈的信号)
  • 「反转字符串 / 数组」
  • 「回文判断」

3. 代码模板

jsx 复制代码
let left = 0;
let right = nums.length - 1;

while (left < right) {
    let sum = nums[left] + nums[right];

    if (sum === target) {
        return [left, right]; // 找到目标,直接返回或记录
    } else if (sum < target) {
        // 和太小,需要更大的数,左指针右移
        left++;
    } else {
        // 和太大,需要更小的数,右指针左移
        right--;
    }
}

练习题目: LeetCode 344(反转字符串)、LeetCode 167(两数之和 II)

相关推荐
dsyyyyy11011 小时前
JavaScript变量
开发语言·javascript·ecmascript
‎ദ്ദിᵔ.˛.ᵔ₎1 小时前
双指针、滑动窗口、前缀和、二分查找 算法
算法
顾北顾1 小时前
多头注意力机制
人工智能·深度学习·算法
H178535090961 小时前
SolidWorks_基于草图的实体特征20_特征错误排查
算法·3d建模·solidworks
kyriewen1 小时前
手写 Promise.all、race、any:不到 30 行代码,解决并发异步的所有姿势
前端·javascript·面试
hujinyuan201601 小时前
2025年12月中国电子学会青少年机器人技术等级考试试卷(二级) 真题+答案
人工智能·算法·机器人
bIo7lyA8v2 小时前
算法复杂度评估的实验统计方法与可视化的技术8
算法
李老师讲编程3 小时前
中国电子学会图形化2020.12月Scratch三级考级题
算法·scratch·信息学奥赛·图形化编程·scratch素材
胡志辉的博客3 小时前
深入浅出理解浏览器事件循环:从一道输出题讲到 Chrome 源码
前端·javascript·chrome·chromium·event loop
代码不加糖3 小时前
js中不会冒泡的事件有哪些?
前端·javascript·vue.js