算法篇1-----双指针

接下来也将进行算法的练习,先从简单的双指针开始,以8道列题来透彻理解算法双指针。

1、

定义两个指针,cur,dest

两指针的作用:cur:从左到右扫描数组,遍历数组

dest:已处理的区间内,非0元素的最后一个位置

cur:1>遇到0元素,cur++

2>遇到非0元素,swap(dest+1,cur);

dest++,cur++;

2、

先根据"异地"操作,然后优化成双指针下的就地操作

1>先找到最后一个复写的数

a、先判断cur位置的值

b、决定dest向后移动一步或者两步

c、判断一下dest是否已经到结束为止

d、cur++

1.5>处理一下边界问题

【1,0,2,3,0,4】此为特殊情况

2>从后向前完成

3、

这道题相当于判断链表是否有环

快慢双指针

a、定义快慢双指针

b、慢每次向后一步,快指针移动两步

c、判断相遇时候的值即可

4、

找出其中的两条线,使得它们与x轴共同构成的容器可以容纳最多的水。

可以进行暴力枚举,但是会超时,不是最优解。所以利用单调性,使用双指针。

5、

暴力枚举依然可行,用伪代码简单说明一下

for(i=0;i<n;i++)

for(j=i+!;k<n;j++)

for(k=j+1;k<n;k++)

check(i,j,k)

这样写时间复杂度达到了o(n)

优化:先对整个数组排序

再利用单调性,使用双指针算法

x:a+b>c----->right-left,right--

y:a+b<=c------->left++

6、输入一个递增排序的数组和一个数字,再数组中查找两个数,使得它们的和正好时s,如果右多对数字的和等于s,则输出任意一对

若sum>t right--

sum<t left++

sum==t 返回结果

7、

这道题考验代码能力,需要多次练习

排序+暴力枚举+利用set去重,复杂

使用双指针加排序

a、排序

b、固定一个数

c、在该数后面的区间内,利用双指针快速找到两个的和等于-target即可

细节问题:不漏,找到一种结果,不要停,继续查找,当使用玩双指针算法之后,i也需要跳过重复的元素,注意避免越界。

8、

这道题与第7题类似,不再赘述

相关推荐
KAU的云实验台9 分钟前
【算法精解】AIR期刊算法IAGWO:引入速度概念与逆多元二次权重,可应对高维/工程问题(附Matlab源码)
开发语言·算法·matlab
会编程的土豆16 分钟前
【数据结构与算法】再次全面了解LCS底层
开发语言·数据结构·c++·算法
大熊背1 小时前
如何利用Lv值实现三级降帧
算法·自动曝光·lv·isppipeline
大尚来也1 小时前
驾驭并发:.NET多线程编程的挑战与破局之道
java·前端·算法
向阳而生,一路生花1 小时前
深入浅出 JDK7 HashMap 源码分析
算法·哈希算法
君义_noip2 小时前
信息学奥赛一本通 4150:【GESP2509七级】⾦币收集 | 洛谷 P14078 [GESP202509 七级] 金币收集
c++·算法·gesp·信息学奥赛·csp-s
摸个小yu2 小时前
【力扣LeetCode热题h100】链表、二叉树
算法·leetcode·链表
汀、人工智能2 小时前
[特殊字符] 第93课:太平洋大西洋水流问题
数据结构·算法·数据库架构·图论·bfs·太平洋大西洋水流问题
ZPC82102 小时前
rviz2 仿真控制器与真实机器人切换
人工智能·算法·机器人
澈2072 小时前
双指针,数组去重
c++·算法