双指针及滑动窗口类题目总结

本文总结了双指针在数组操作中的应用,包括从两端向中间迭代的反转字符串等问题,以及快慢指针在移除数组元素中的使用。并列举了相关LeetCode题目,如344.反转字符串、27.移除元素等,展示了双指针在实际问题中的解决方案。同时,提到了滑动窗口在209.长度最小的子数组等题目的应用。
摘要由CSDN通过智能技术生成

双指针

情景一

我们通过迭代数组来解决一些问题。通常,我们只需要一个指针进行迭代,即从数组中的第一个元素开始,最后一个元素结束。然而,有时我们会使用两个指针进行迭代。

经典案例

反转数组中的元素。比如数组为 ['l', 'e', 'e', 't', 'c', 'o', 'd', 'e'],反转之后变为['e', 'd', 'o', 'c', 't', 'e', 'e', 'l']

使用双指针技巧,其思想是分别将两个指针分别指向数组的开头及末尾,然后将其指向的元素进行交换,再将指针向中间移动一步,继续交换,直到这两个指针相遇。

def reverseString(self, s):
    i, j = 0, len(s) - 1
    while i < j:
        s[i], s[j] = s[j], s[i]
        i += 1
        j -= 1

小结

我们来总结一下,使用双指针的典型场景之一是你想要

从两端向中间迭代数组。

这时你可以使用双指针技巧:

一个指针从头部开始,而另一个指针从尾部开始。

这种技巧经常在排序数组中使用。

Leetcode相关题目
题目方法Java代码
344. 反转字符串双指针戳我
561. 数组拆分 I双指针戳我
167. 两数之和 II - 输入有序数组双指针戳我

情景二

有时,我们可以使用两个不同步的指针来解决问题,即快慢指针。与情景一不同的是,两个指针的运动方向是相同的,而非相反。

经典问题:

给你一个数组nums和一个值val,你需要 原地 移除所有数值等于val的元素,并返回移除后数组的新长度。

如果我们没有空间复杂度上的限制,那就更容易了。我们可以初始化一个新的数组来存储答案。如果元素不等于给定的目标值,则迭代原始数组并将元素添加到新的数组中。

在这里插入图片描述
实际上,它相当于使用了两个指针,一个用于原始数组的迭代,另一个总是指向新数组的最后一个位置。

Leetcode相关题目
题目方法Java代码
27. 移除元素双指针戳我
485. 最大连续 1 的个数双指针戳我
209. 长度最小的子数组双指针、滑动窗口戳我
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值