算法之双指针

双指针算法的作用

双指针算法是一种使用2个变量对线性结构(逻辑线性/物理线性),进行操作的算法,双指针可以对线性结构进行时间复杂度优化,可以对空间进行记忆。

双指针算法的分类

1.快慢指针

2.滑动窗口

3.左右指针

4.前后指针

双指针OJ题目

Leetcode.27.移除元素

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

不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地修改输入数组

元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

使用左右指针,一个指向左值,一个指向右值。

Leetcode.15.三数之和

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != kj != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

**注意:**答案中不可以包含重复的三元组。

排序+双指针(前后指针),排序用来剪枝。

通过i遍历整个数组,得到第一个数,left,right得到其他2个数,因为数组被排序后,只要sum大于0,则right--,若小于0,则left++,对比暴力算法,双指针减少了一次遍历,降低了时间复杂度。

Leetcode.209.长度最小子数组

给定一个含有 n个正整数的数组和一个正整数 target

找出该数组中满足其总和大于等于target的长度最小的 连续子数组 [numsl, numsl+1, ..., numsr-1, numsr] ,并返回其长度**。** 如果不存在符合条件的子数组,返回 0

滑动窗口

Leetcode.151.反转字符串

给你一个字符串 s ,请你反转字符串中 单词 的顺序。

单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。

返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。

注意: 输入字符串 s中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。

前后指针,左右指针,整体反转,局部反转,去除重复空格。

相关推荐
先做个垃圾出来………10 分钟前
哈夫曼树(Huffman Tree)
数据结构·算法
Inverse1622 小时前
C语言_动态内存管理
c语言·数据结构·算法
liang_20264 小时前
【HT周赛】T3.二维平面 题解(分块:矩形chkmax,求矩形和)
数据结构·笔记·学习·算法·平面·总结
进击的小白菜4 小时前
LeetCode 153. 寻找旋转排序数组中的最小值:二分查找法详解及高频疑问解析
数据结构·算法·leetcode
士别三日&&当刮目相看5 小时前
数据结构*优先级队列(堆)
java·数据结构
QQ_4376643145 小时前
单向循环链表C语言实现实现(全)
数据结构·windows·链表
ptu小鹏6 小时前
list重点接口及模拟实现
数据结构·c++·list
冲帕Chompa7 小时前
图论part10 bellman_ford算法
数据结构·算法·图论
GG不是gg7 小时前
排序算法之基础排序:冒泡,选择,插入排序详解
数据结构·算法·青少年编程·排序算法
丶Darling.9 小时前
Day119 | 灵神 | 二叉树 | 二叉树的最近共公共祖先
数据结构·c++·算法·二叉树