一、基础算法6:双指针算法 模板题+算法模板(最长连续不重复子序列,数组元素的目标和,判断子序列)

news2025/1/18 16:51:22

文章目录

  • 算法模板
    • 双指针算法模板
    • 最长连续不重复子序列模板
      • 暴力法
      • 双指针算法
    • 数组元素的目标和模板
    • 判断子序列模板
  • 模板题
    • 最长连续不重复子序列
      • 原题链接
      • 题目
      • 题解
    • 数组元素的目标和
      • 原题链接
      • 题目
      • 题解
    • 判断子序列
      • 原题链接
      • 题目
      • 题解

算法模板

双指针算法模板

for (int i = 0, j = 0; i < n; i ++ )
{
    while (j < i && check(i, j)) j ++ ;

    // 具体问题的逻辑
}
常见问题分类:
    (1) 对于一个序列,用两个指针维护一段区间
    (2) 对于两个序列,维护某种次序,比如归并排序中合并两个有序序列的操作

最长连续不重复子序列模板

暴力法

//暴力法check函数
int check(int l, int r)
{
    for (int i = l+1; i <=r ; i++)
        for (int j = l; j < i; j++)
            if (a[i] == a[j])
                return 1;
    return 0;
} 
//暴力法: 
	for (int i = 0; i < n; i++)
		for (int j = 0; j <= i; j++)
			if (check(j, i) == 0)//检查 i 和 j 之间是否有重复的数字
				res = max(res, i - j + 1);
				
	cout<<res;

双指针算法

//	双指针算法:
	for(int i=1,j=1;i<=n;i++){
		s[a[i]]++;
		while(s[a[i]]>1){ // 此时a[i]在序列中有重复值 
			s[a[j]]--; //  在s中-- 维护s数组 
			j++;// j++ j在左边找到第一个和a[i]重复的值 并维护j~i序列中没有重复的数 
		}
		res = max(res,i-j+1);
		
	} 
	cout<<res;

数组元素的目标和模板

	int j=m-1;
	for(int i=0;i<n;i++){
		while(j>=0 && a[i]+b[j]>x) j--;
		if(a[i]+b[j] == x){
			printf("%d %d\n",i,j);
			break;
		}
	}

判断子序列模板

	int i=0,j=0;
	while(i<n && j<m){
		if(a[i] == b[j]) i++;
		j++; 
	}	
	if(i==n) cout<<"Yes";
	else cout<<"No";

模板题

最长连续不重复子序列

原题链接

https://www.acwing.com/problem/content/801/

题目

799 . 最长连续不重复子序列
给定一个长度为 n
的整数序列,请找出最长的不包含重复的数的连续区间,输出它的长度。

输入格式
第一行包含整数 n

第二行包含 n
个整数(均在 0∼105
范围内),表示整数序列。

输出格式
共一行,包含一个整数,表示最长的不包含重复的数的连续区间的长度。

数据范围
1≤n≤105
输入样例:

5
1 2 2 3 5

输出样例:

3

题解

在这里插入图片描述

#include <iostream>
using namespace std;

const int N = 1e5 + 10;
int n;
int a[N],s[N];

暴力法check函数
//int check(int l, int r)
//{
//    for (int i = l+1; i <=r ; i++)
//        for (int j = l; j < i; j++)
//            if (a[i] == a[j])
//                return 1;
//    return 0;
//} 
int main() {
	cin>>n;
	for(int i=1; i<=n; i++) cin>>a[i];

	int res = 0;
//	//暴力法: 
//	for (int i = 0; i < n; i++)
//		for (int j = 0; j <= i; j++)
//			if (check(j, i) == 0)//检查 i 和 j 之间是否有重复的数字
//				res = max(res, i - j + 1);
//				
//	cout<<res;

//	双指针算法:
	for(int i=1,j=1;i<=n;i++){
		s[a[i]]++;
		while(s[a[i]]>1){ // 此时a[i]在序列中有重复值 
			s[a[j]]--; //  在s中-- 维护s数组 
			j++;// j++ j在左边找到第一个和a[i]重复的值 并维护j~i序列中没有重复的数 
		}
		res = max(res,i-j+1);
		
	} 
	cout<<res;
	return 0;
}

数组元素的目标和

原题链接

https://www.acwing.com/problem/content/802/

题目

800 . 数组元素的目标和
给定两个升序排序的有序数组 A
和 B
,以及一个目标值 x

数组下标从 0
开始。

请你求出满足 A[i]+B[j]=x
的数对 (i,j)

数据保证有唯一解。

输入格式
第一行包含三个整数 n,m,x
,分别表示 A
的长度,B
的长度以及目标值 x

第二行包含 n
个整数,表示数组 A

第三行包含 m
个整数,表示数组 B

输出格式
共一行,包含两个整数 i
和 j

数据范围
数组长度不超过 105

同一数组内元素各不相同。
1≤数组元素≤109
输入样例:

4 5 6
1 2 4 7
3 4 6 8 9

输出样例:

1 1

题解

在这里插入图片描述
在这里插入图片描述

#include <iostream>
using namespace std;
const int N = 1e5 + 10;

int a[N],b[N];
int n,m,x;
int main(){
	scanf("%d%d%d",&n,&m,&x);
	
	for(int i=0;i<n;i++) scanf("%d",&a[i]);
	for(int i=0;i<m;i++) scanf("%d",&b[i]);
	
	int j=m-1;
	for(int i=0;i<n;i++){
		while(j>=0 && a[i]+b[j]>x) j--;
		if(a[i]+b[j] == x){
			printf("%d %d\n",i,j);
			break;
		}
	}
	return 0;
}

判断子序列

原题链接

https://www.acwing.com/problem/content/2818/

题目

2816 . 判断子序列
给定一个长度为 n
的整数序列 a1,a2,…,an
以及一个长度为 m
的整数序列 b1,b2,…,bm

请你判断 a
序列是否为 b
序列的子序列。

子序列指序列的一部分项按原有次序排列而得的序列,例如序列 {a1,a3,a5}
是序列 {a1,a2,a3,a4,a5}
的一个子序列。

输入格式
第一行包含两个整数 n,m

第二行包含 n
个整数,表示 a1,a2,…,an

第三行包含 m
个整数,表示 b1,b2,…,bm

输出格式
如果 a
序列是 b
序列的子序列,输出一行 Yes。

否则,输出 No。

数据范围
1≤n≤m≤105
,
−109≤ai,bi≤109
输入样例:

3 5
1 3 5
1 2 3 4 5

输出样例:

Yes

题解

#include <iostream>
using namespace std;
const int N = 1e5 + 10;
int a[N],b[N];
int n,m;

int main(){
	scanf("%d%d",&n,&m);
	for(int i=0;i<n;i++) scanf("%d",&a[i]);
	for(int i=0;i<m;i++) scanf("%d",&b[i]);
	
	int i=0,j=0;
	while(i<n && j<m){
		if(a[i] == b[j]) i++;
		j++; 
	}	
	if(i==n) cout<<"Yes";
	else cout<<"No";
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/418785.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ForkJoinPool + RecursiveTask 来计算数组元素和

ForkJoinPool 是什么&#xff1f; ForkJoinPool 是一个 Java 并发编程框架&#xff0c;用于解决分治算法中的任务拆分、执行、合并等问题&#xff0c;是 Java 7 引入的一个新的工具类。 ForkJoinPool 的基本思想是将一个大任务划分成若干个小任务&#xff0c;然后并行执行这些…

SQL AVG函数

SQL AVG函数 SQL AVG函数简介 SQL AVG函数是一个聚合函数&#xff0c;用于计算集合的平均值。 以下说明了SQL AVG函数的语法&#xff1a; AVG([ALL|DISTINCT] expression)如果使用ALL关键字&#xff0c;AVG函数将获取计算中的所有值。 默认情况下&#xff0c;无论是否指定&a…

python+vue 图书馆读者行为分析系统-书友会

本系统主要包括以下功能模块&#xff1a;个人中心、用户管理、图书信息管理、图书分类管理、热门图书管理、书友会管理、报名信息管理、行为分析管理、在线论坛、系统管理等模块&#xff0c;通过这些模块的实现能够基本满足日常图书馆读者行为分析系统的操作。结合相关设计模式…

生成式 AI 与强人工智能:探索 AI 技术的未来

AIGC&#x1f388; AIGC&#xff08;AI Generated Content&#xff09; 即人工智能生成内容&#xff0c;又称“生成式 AI”&#xff08;Generative AI&#xff09;&#xff0c;被认为是继专业生产内容&#xff08;PGC&#xff09;、用户生产内容&#xff08;UGC&#xff09;之…

rust中的集合容器(切片和哈希)与错误处理

String、数组[T:n]、列表Vec\哈希表HashMap<K,V>等。 切片slice&#xff1b; 循环缓冲区 VecDeque、双向列表 LinkedList等。(这是指双向链表吗&#xff1f;) 这些集合容器的共性&#xff1a; 可以遍历 可以进行 map-reduce操作。 可以从一种类型转换成另一种类型。 主要…

VUE使用el-ui的form表单输入框批量搜索<VUE专栏三>

针对form表单的输入框单号批量查询&#xff0c;这里用换行符进行分割&#xff0c;注意v-model不要使用.trim 前端代码&#xff1a; <el-form-item label"SKU编码:" prop"prodNumbers"><el-input type"textarea" :rows"4" pla…

阿里数学竞赛决赛名单公布:北大人数是清华4倍 | 最小仅14岁

4月10日消息&#xff0c;第二届阿里巴巴全球数学竞赛决赛入围名单公布&#xff0c;全球12个国家516位选手晋级&#xff0c;晋级率仅有1&#xff05;。 根据参赛者填报信息&#xff0c;晋级选手80&#xff05;以上是90后&#xff0c;年纪最小的只有14岁。 入围人数最高的前20所高…

【Linux】git命令(基础,新手)

文章目录1.查看当前git版本信息2.安装git3.将远端仓库克隆到本地4.三板斧第一招&#xff1a;git add5.三板斧第二招&#xff1a;git commit6.三板斧第三招&#xff1a;git push7.对仓库文件进行更改8.查看使用提交日志9.查看本地与远端的同步状态10.从远端仓库拉取最新版本文件…

ChatGPT Plus价格太贵,可以约上三五知己一起上车体验一下,这个项目就能帮到你

❝ 对于想体验ChatGPT PLus的小伙伴&#xff0c;可能觉得自己一个人一个月花费20美元&#xff0c;相对于人民币每月137多&#xff0c;确实是一个不少的开支&#xff0c;如果&#xff0c;几个人合作一个账号&#xff0c;这样负担就减少了。刚好&#xff0c;最近逛github发现刚好…

深度学习-第R2周——LSTM火灾温度预测

深度学习-第R2周——LSTM火灾温度预测深度学习-第R2周——LSTM火灾温度预测一、前言二、我的环境三、前期工作1、导入数据集2、数据可视化四、构建数据集1、设置x,y2、归一化3、划分数据集五、构建模型六、模型训练1、编译2、训练七、评估1、loss图2、预测深度学习-第R2周——L…

MySQL数据库实现主主同步

前言 MySQL主主同步实际上是在主从同步的基础上将从数据库也提升成主数据库&#xff0c;让它们可以互相读写数据库&#xff0c;从数据库变成主数据库&#xff1b;主从相互授权连接&#xff0c;读取对方binlog日志并更新到本地数据库的过程,只要对方数据改变&#xff0c;自己就…

K均值聚类分析流程

K均值聚类分析流程 一、案例背景 在某体育赛事中&#xff0c;意大利、韩国、罗马尼亚、法国、中国、美国、俄罗斯七个国家的裁判对300名运动员进行评分&#xff0c;现在想要通过评分上的差异将300名选手进行分类&#xff0c;计划将选手分为高水平、中水平、低水平三个类别。因…

Unity2D 商业游戏案例 - 梦幻西游(第二季 框架设计篇)

00 网址 来源 siki学院的&#xff08;1年有限期到期前下载的项目&#xff0c;现在已经过期&#xff0c;所以自己理清项目&#xff09; 所以更多的不是学习这个项目&#xff0c;而是学习理清该类型的项目的思路 Unity2D 商业游戏案例 - 梦幻西游&#xff08;第二季 框架设计篇&…

python+vue 在线考试系统的设计与实现

1.用户登录 用户要通过本系统查询对课程信息进行下载&#xff0c;必须先输入用户名和密码进行登陆。为了避免非其他人员都可以获得登陆权限&#xff0c;登陆系统不设注册过程&#xff0c;所有用户和教师的登陆信息将事先由管理人员直接对数据库进行录入。 2.教师 教师登录系统后…

【排序】排序这样写才对Ⅱ -冒泡排序与快速排序Ⅰ

Halo&#xff0c;这里是Ppeua。平时主要更新C语言&#xff0c;C&#xff0c;数据结构算法......感兴趣就关注我吧&#xff01;你定不会失望。 &#x1f308;个人主页&#xff1a;主页链接 &#x1f308;算法专栏&#xff1a;专栏链接 我会一直往里填充内容哒&#xff01; &…

【Spring6】| Spring6整合JUnit

目录 一&#xff1a;Spring6整合JUnit 1. Spring对JUnit4的支持 2. Spring对JUnit5的支持 一&#xff1a;Spring6整合JUnit 1. Spring对JUnit4的支持 准备工作&#xff1a;pom.xml 注&#xff1a;以前是直接使用单元测试Junit&#xff0c;现在使用Spring对Junit的整合&…

快递电子运单上,电话应隐藏6位以上,禁止显示这些信息

我国快递年业务量达千亿件&#xff0c;快递电子运单是应用于快递外包装的重要单据&#xff0c;每年耗用量很大。在强化个人信息保护方面&#xff0c;《快递电子运单》国家标准要求快递企业、电商经营主体等采取措施&#xff0c;避免在电子运单上显示完整的收寄件人个人信息。 …

【机器学习】P14 Tensorflow 使用指南 Dense Sequential Tensorflow 实现

Tensorflow 第一节&#xff1a;使用指南Tensorflow 安装神经网络一些基本概念隐藏层和输出层&#xff1a;神经元的输出公式Tensorflow 全连接层 Dense 与 顺序模型 SequentialDense LayerSequential Model代码实现一个神经网络实现方式一&#xff1a;手写神经网络* 实现方式二&…

JavaScript基础入门全解析(上)

JavaScript基础语法 什么是JavaScript&#xff08;简称js&#xff09; 1.首先了解前端页面的组成&#xff08;前端页面的三层结构&#xff09; ●HTML 表示了你的页面内有什么&#xff0c;组成页面的骨架 &#xff08;结构层&#xff09; ●CSS 表示了你的页面中每一个内容是…

Linux系统中安装新版本nacos(centos7)

1. 背景需求 由于一些限制,在客户现场的Linux操作系统中,没有安装docker k8s等容器,无法直接使用镜像安装,而且客户要求只能在原始的操作系统中安装最新版的nacos,(为什么需要安装最新版的nacos,因为检测国网检测到之前版本的nacos有漏洞,需要安装新版的nacos). 2. 下载nacos…