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

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

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)

相关推荐
智者知已应修善业1 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.5481 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove2 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊2 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
豹哥学前端3 小时前
用猜数字游戏,一口气掌握 JavaScript 核心知识点(附完整代码)
前端·javascript
忆往wu前3 小时前
从0到1一步步拆解搭建,梳理一个 Vue3 简易图书后台全开发流程
前端·javascript·vue.js
code_pgf3 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
嘻嘻哈哈樱桃3 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划
shao9185163 小时前
第3章(2)——使用Gradio JavaScript Client
javascript·node.js·cdn·gradio·job·events·playcode
光影少年4 小时前
大屏页面,一次多个请求,请求加密导致 点击 全局时间选择器 时出现卡顿咋解决(面板收起会延迟1~2秒)
前端·javascript·vue.js·学习·前端框架·echarts·reactjs