首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

指针】早早开启指针的大门

同向指针 移动速度相同,一般同向移动 双向指针 移动速度相同,一般相向移动 快慢指针 移动速度不同 问题1:同向指针: 图片 【力扣】1....两数之和 图片 解题; 使用同向指针,两个指针首先都指向第一个元素,然后先固定第一个指针,第二个指针向后遍历,判断两个指针指向的数组元素之和是否等于给定的目标和值,如果不等,等第二个指针遍历完后...问题2:双向指针:(还是两数之和那题) 图片 解题: 注意到该数组原本有序,因此要小心,再思考一下下 我们可以使第一个指针指向第一个元素(左指针),第二个指针指向最后一个元素(右指针),将指针指向的元素相加和目标和值比较...,由于数组是有序的: 如果两指针指向的数组元素相加之和大于目标和值,就使右指针回退一位,左指针不动; 如果两指针指向的数组元素相加之和小于目标和值,就使左指针回退一位,右指针不动; 如果两指针指向的数组元素相加之和等于目标和值...在数组中%d和%d的和为%d\n", a[left], a[right], key); break; } } return 0; } 问题3:快慢指针

55830
您找到你想要的搜索结果了吗?
是的
没有找到

【算法】指针算法 ( 指针算法分类 | 相向指针 | 有效回文串 )

文章目录 一、指针算法分类 二、相向指针示例 ( 有效回文串 ) 一、指针算法分类 ---- 面试时经常遇到 限制算法复杂度为 O ( n ) 的情况 , 就需要使用以下算法 : 指针算法...; 单调栈算法 ; 单调队列算法 ; 指针算法分类 : 相向指针 : 判断一个字符串是否是回文串 , 从两边向中心遍历 ; 背向指针 : 查找一个字符串的最长回文子串使用的 " 中心线枚举算法 "...就是背向指针算法 , 从中心向两边遍历 ; ( 出现频率较 - 低 ) 同向指针 : 相向指针算法分类 : 翻转类型 : ① 翻转字符串 , ② 判断回文串 ; 两个指针分别指向收尾 , 两边往中间走...两数之和型 : ① 两数之和 , ② 三数之和 ; 分割类型 : ① 快速排序 , ② 颜色排序 ; 给定一个数组 , 将其分割成两部分 , 一部分满足某条件 , 另外一部分不满足某条件 ; 二、相向指针示例...(c) || Character.isDigit(c); } /** * 对比两个字符是否相等, 忽略大小写, 先将字符转为小写字母, 然后再对比 * @param

1.8K10

算法:指针

指针 指针是一种思想或一种技巧并不是特别具体的算法。具体就是用两个变量动态存储两个结点,来方便我们进行一些操作。通常用在线性的数据结构中。...特别是链表类的题目,经常需要用到两个或多个指针配合来记忆链表上的节点,完成某些操作。 常见的指针方式 •同速指针:链表上两个指针,一个先出发,另一个后出发并以相同的速度跟随。...•求链表的逆:通过临时指针指针同步前行•求链表倒数第k个元素:先让其中一个指针向前走k步,接着两个指针以同样的速度一起 向前进,直到前面的指针走到尽头了,则后面的指针即为倒数第k个元素 •快慢指针:...指针常用于线性结构:链表,数组 例题 151.反转链表 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。...输出:[1,2] 示例 2: 输入:head = [1,1,2,3,3] 输出:[1,2,3] 解题思路: •方法1:使用栈的思想,如果后面入的元素与栈顶元素相同,就略过该元素,继续遍历•方法2:指针

30620

【算法专题】指针

指针 指针 常见的指针有两种形式,⼀种是对撞指针,⼀种是左右指针。 对撞指针:⼀般用于顺序结构中,也称左右指针。 对撞指针从两端向中间移动。...那我们可以利用在两数之和那里用的指针思想,来对我们的暴力枚举做优化: i. 先排序; ii. 然后固定⼀个数 a : iii....在这个数后⾯的区间内,使用「指针算法」快速找到两个数之和等于 -a 即可。 但是要注意,这道题里面需要有「去重」操作: i....请你找出并返回满足下述全部条件且不重复的四元组[nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复): 0 <= a, b, c,...d < n a、b、c 和 d 互不相同 nums[a] + nums[b] + nums[c] + nums[d] == target 你可以按 任意顺序 返回答案 。

8510

指针-two pointers

例如在一个递增序列中找到a+b=c的数然后输出a,b的值,M是我们自己指定的数,常规做法很容易想到,两个下标遍历序列做个二重循环就可以解决问题,时间复杂度为o(n^2)。...]=M,想要继续分析找到合适的i和j,下一步应该如何选择才能更加的高效,显然可以从给出的背景条件来看,由A序列是个递增序列可以知道,如果在找到的上述A[i]+A[j]=M条件下将i单独后移显然结果大于c的...,而将j前移显然后来的结果都是小于c的,所以下一个查找区间应该[i+1,j-1]开始。...但请好好分析下,这个思想应该是不太难的,用此方法实现复杂度显然降低不少,此时复杂度为o(n),实现的伪代码如下: while(i<j) { if(a[i]+a[j]==c)...two pointers的应用场景 序列合并问题 归并排序 快速排序 参考 two pointers、归并排序、快速排序问题 版权所有:可定博客 © WNAG.COM.CN 本文标题:《指针-two

29610

LeetCode-指针

指针 指针主要用于遍历数组,两个指针指向不同的元素,从而协同完成任务。...解法: 使用指针,一个指针指向值较小的元素,一个指针指向值较大的元素。指向较小元素的指针从头向尾遍历,指向较大元素的指针从尾向头遍历。...示例: 输入: "hello" 输出: "holle" 输入: "leetcode" 输出: "leotcede" 解法: 使用指针指向待反转的两个元音字符,一个指针从头向尾遍历,一个指针从尾到头遍历...一般而言,对于有序数组可以通过 指针法 达到O(n + m)O(n+m)的时间复杂度。...解法: 使用指针,一个指针每次移动一个节点,一个指针每次移动两个节点,如果存在环,那么这两个指针一定会相遇。

49640

【算法】指针算法

二、算法原理 如果用指针从前往后遍历,就拿例1来说, 就会出现值被覆盖的情况: 所以遍历顺序就不能从前往后。...可以先用指针算法:1.先判断cur位置;2.决定dest向后移动一步或者两步;3.判断一下dest是否已经到达结束位置;4.在把cur加加。...二、算法原理 利用数组是有序的,用指针算法来算。 定义两个指针,一个在左边,一个在右边。...二、算法原理 排序之后,数据是有序的,这里就用指针算法。...这里是三个数的和,可以先固定一个数a,仅想要保证这个a是小于0就行(在后面等于0相加的值不可能等于0),然后在该数后面的区间内,利用指针算法,快速找到两个数的和,者两个数的和是a的相反数,这样这三个数相加的时候

6500

【刷题】指针进阶

请看入门篇 :指针入门 送给我们一句话: 如今我努力奔跑,不过是为了追上那个曾经被寄予厚望的自己 —— 约翰。...今天我继续学习了指针的题目,继续探索了指针的进阶用法。其中包括对撞指针,单调性分析指针。接下来我带大家一起复盘一下我做的三道题目,来深入了解一下指针算法的进阶版本。...在入门篇中我们基本知道了指针的思路,即控制两个指向分别按条件转换,这样配合排序算法可以大大降低算法的时间复杂度。 而接下来我们继续学习,来看看指针对复杂问题的解决。...那如何把指针使用到里面呢? 首先我们来看check的过程: 思路与算法 对于正整数 a,b,c它们可以作为三角形的三条边,当且仅当: a+b>c a+c>b b+c>a 均成立。...(如果使用暴力算法,就直接超时了) 所以指针的算法是非常高效的算法,并且一般有序问题都可以进行求解!

6110
领券