双指针技巧秒杀七道数组题目

简介: 本文介绍数组与链表中常用的双指针技巧,包括快慢指针与左右指针。通过LeetCode经典题目如删除有序数组/链表中的重复项、两数之和等,详解如何用快慢指针实现原地修改,提升算法效率,适用于刷题进阶与面试备考。(238字)

LeetCode 力扣 难度

  1. Two Sum II - Input Array Is Sorted 167. 两数之和 II - 输入有序数组 🟠
  2. Remove Duplicates from Sorted Array 26. 删除有序数组中的重复项 🟢
  3. Remove Element 27. 移除元素 🟢
  4. Move Zeroes 283. 移动零 🟢
  5. Reverse String 344. 反转字符串 🟢
  6. Longest Palindromic Substring 5. 最长回文子串 🟠
  7. Remove Duplicates from Sorted List 83. 删除排序链表中的重复元素 🟢
  • 剑指 Offer 57. 和为s的两个数字 🟢
  • 剑指 Offer II 006. 排序数组中两个数字之和 🟢
    处理数组和链表相关问题时,双指针技巧是经常用到的,双指针技巧主要分为两类:左右指针和快慢指针。所谓左右指针,就是两个指针相向而行或者相背而行;而所谓快慢指针,就是两个指针同向而行,一快一慢。对于单链表来说,大部分技巧都属于快慢指针,单链表的六大解题套路 都涵盖了,比如链表环判断,倒数第 K 个链表节点等问题,它们都是通过一个 fast 快指针和一个 slow 慢指针配合完成任务。
    在数组中并没有真正意义上的指针,但我们可以把索引当做数组中的指针,这样也可以在数组中施展双指针技巧,本文主要讲数组相关的双指针算法
    快慢指针技巧
    原地修改
    数组问题中比较常见的快慢指针技巧,是让你原地修改数组。
    比如说看下力扣第26题「删除有序数组中的重复项」,让你在有序数组去重:
  1. 删除有序数组中的重复项 | 力扣 | LeetCode | 🟢
    给你一个 非严格递增排列 的数组 nums ,请你原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。
    考虑 nums 的唯一元素的数量为 k ,你需要做以下事情确保你的题解可以被通过:
    ● 更改数组 nums ,使 nums 的前 k 个元素包含唯一元素,并按照它们最初在 nums 中出现的顺序排列。nums 的其余元素与 nums 的大小不重要。
    ● 返回 k 。
    判题标准:
    系统会用下面的代码来测试你的题解:
    int[] nums = [...]; // 输入数组
    int[] expectedNums = [...]; // 长度正确的期望答案
    int k = removeDuplicates(nums); // 调用
    assert k == expectedNums.length;
    for (int i = 0; i < k; i++) {
    assert nums[i] == expectedNums[i];
    }
    如果所有断言都通过,那么您的题解将被 通过。
    示例 1:
    输入:nums = [1,1,2]
    输出:2, nums = [1,2,_]
    解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素。
    示例 2:
    输入:nums = [0,0,1,1,1,2,2,3,3,4]
    输出:5, nums = [0,1,2,3,4]
    解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。
    提示:
    ● 1 <= nums.length <= 3 * 104
    ● -104 <= nums[i] <= 104
    ● nums 已按 非严格递增 排列
    函数签名如下:
    int removeDuplicates(int[] nums);
    简单解释一下什么是原地修改:
    如果不是原地修改的话,我们直接 new 一个 int[] 数组,把去重之后的元素放进这个新数组中,然后返回这个新数组即可。但是现在题目让你原地删除,不允许 new 新数组,只能在原数组上操作,然后返回一个长度,这样就可以通过返回的长度和原始数组得到我们去重后的元素有哪些了。
    由于数组已经排序,所以重复的元素一定连在一起,找出它们并不难。但如果毎找到一个重复元素就立即原地删除它,由于数组中删除元素涉及数据搬移,整个时间复杂度是会达到 O(N2)O(N2)。
    高效解决这道题就要用到快慢指针技巧:
    我们让慢指针 slow 走在后面,快指针 fast 走在前面探路,找到一个不重复的元素就赋值给 slow 并让 slow 前进一步。这样,就保证了 nums[0..slow] 都是无重复的元素,当 fast 指针遍历完整个数组 nums 后,nums[0..slow] 就是整个数组去重之后的结果。
    看代码:
    class Solution {
    public int removeDuplicates(int[] nums) {
    if (nums.length == 0) {
        return 0;
    }
    int slow = 0, fast = 0;
    while (fast < nums.length) {
        if (nums[fast] != nums[slow]) {
            slow++;
            // 维护 nums[0..slow] 无重复
            nums[slow] = nums[fast];
        }
        fast++;
    }
    // 数组长度为索引 + 1
    return slow + 1;
    
    }
    }
    再简单扩展一下,看看力扣第 83 题「删除排序链表中的重复元素」,如果给你一个有序的单链表,如何去重呢?其实和数组去重是一模一样的,唯一的区别是把数组赋值操作变成操作指针而已,你对照着之前的代码来看:
    class Solution {
    public ListNode deleteDuplicates(ListNode head) {
    if (head == null) return null;
    ListNode slow = head, fast = head;
    while (fast != null) {
        if (fast.val != slow.val) {
            // nums[slow] = nums[fast];
            slow.next = fast;
            // slow++;
            slow = slow.next;
        }
        // fast++
        fast = fast.next;
    }
    // 断开与后面重复元素的连接
    slow.next = null;
    return head;
    
    }
    }
相关文章
|
小程序 JavaScript 前端开发
小程序入门及案例展示
小程序入门及案例展示
794 0
|
机器学习/深度学习 Web App开发 算法
ML之RF:随机森林RF算法简介、应用、经典案例之详细攻略
随机森林指的是利用多棵决策树对样本进行训练并预测的一种分类器。它包含多个决策树的分类器,并且其输出的类别是由个别树输出的类别的众数而定。随机森林是一种灵活且易于使用的机器学习算法,即便没有超参数调优,也可以在大多数情况下得到很好的结果。随机森林也是最常用的算法之一,因为它很简易,既可用于分类也能用于回归。
ML之RF:随机森林RF算法简介、应用、经典案例之详细攻略
|
7月前
|
机器学习/深度学习 人工智能 搜索推荐
当情绪也能被“量化”:数据如何悄悄改变心理健康分析与治疗
当情绪也能被“量化”:数据如何悄悄改变心理健康分析与治疗
800 14
|
存储 人工智能 运维
阿里云 Tair 基于 3FS 工程化落地 KVCache:企业级部署、高可用运维与性能调优实践
阿里云 Tair KVCache 团队联合硬件团队对 3FS 进行深度优化,通过 RDMA 流量均衡、小 I/O 调优及全用户态落盘引擎,提升 4K 随机读 IOPS 150%;增强 GDR 零拷贝、多租户隔离与云原生运维能力,构建高性能、高可用、易管理的 KVCache 存储底座,助力 AI 大模型推理降本增效。
|
6月前
|
人工智能 NoSQL 前端开发
Chap03. SpringAI
SpringAI整合多款主流大模型,支持对话、函数调用与RAG等架构,提供统一API简化开发。通过ChatClient封装交互,结合Prompt工程、工具调用与知识检索,可快速构建智能客服、哄哄模拟器、ChatPDF等应用,并支持多模态与持久化扩展,助力AI应用高效落地。
|
6月前
|
人工智能 缓存 监控
2025年优测全链路压测平台:高并发卡顿环节精准定位实践
文章围绕2025年高并发场景下系统卡顿问题,阐述全链路压测是精准定位卡顿环节的主流技术。介绍主流全链路压测平台类型及差异,分析卡顿定位面临的挑战,重点讲解优测全链路压测平台的技术优势与实践,还给出落地全链路压测的方法及方案选择建议。
|
7月前
|
弹性计算 数据挖掘 应用服务中间件
租服务器一个月多少钱?跑跑python
阿里云服务器租用价格低至3元/月!轻量应用服务器38元/年,ECS经济型实例99元起/年,2核4G仅需16元/月,适合跑Python脚本、数据挖掘等。高配8核32G仅160元/月,年付更享20%-30%优惠,点击了解详情→
2482 1
|
8月前
|
机器学习/深度学习 人工智能 自然语言处理
47_历史里程碑:从ELIZA到Transformer
在当今的数字时代,我们已经习惯于与智能助手对话、向大语言模型提问,甚至依赖它们生成创意内容。然而,这看似理所当然的人机对话能力,实际上经历了长达半个多世纪的曲折发展历程。从1966年麻省理工学院的简陋程序,到2017年Google提出的革命性架构,聊天AI的演变不仅是技术的进步,更是人类对自身语言本质探索的缩影。
1218 31
|
9月前
|
算法 API 数据安全/隐私保护
深度解析京东图片搜索API:从图像识别到商品匹配的算法实践
京东图片搜索API基于图像识别技术,支持通过上传图片或图片URL搜索相似商品,提供智能匹配、结果筛选、分页查询等功能。适用于比价、竞品分析、推荐系统等场景。支持Python等开发语言,提供详细请求示例与文档。