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

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

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)

相关推荐
天外飞雨道沧桑2 小时前
TypeScript 中 omit 和 record 用法
前端·javascript·typescript
Dlrb12113 小时前
C语言-指针三
c语言·算法·指针·const·命令行参数
Tisfy3 小时前
LeetCode 2540.最小公共值:双指针(O(m+n))
算法·leetcode·题解·双指针
IronMurphy3 小时前
【算法四十七】152. 乘积最大子数组
算法
淘矿人4 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
Cosolar4 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
暗冰ཏོ5 小时前
VUE面试题大全
前端·javascript·vue.js·面试
落羽的落羽6 小时前
【算法札记】练习 | Week4
linux·服务器·数据结构·c++·人工智能·算法·动态规划
萑澈7 小时前
算法竞赛入门:C++ STL核心用法与时空复杂度速查手册
数据结构·c++·算法·stl