洛谷p3901题解

题目描述

现有数列 A1,A2,...,AN,QQ 个询问 (Li,Ri),询问 ALi,ALi+1,...,ARi​​ 是否互不相同。

输入格式

第一行,两个整数N,Q。

第二行,NN 个整数A1,A2,...,AN​。

接下来 QQ 行,每行两个整数 Li,Ri。

输出格式

对每个询问输出一行,YesNo

输入输出样例

输入 #1复制

复制代码
4 2
1 2 3 2
1 3
2 4

输出 #1复制

复制代码
Yes
No

说明/提示

对于 50% 的数据,N,Q≤103。

对于 100%的数据,1≤N,Q≤105,1≤Ai≤N,1≤Li≤Ri≤N。

思路:

很显然,这道题我们可以用莫队做,但是我不会对新手不友好,所以这里用了一种简单的方法水过去。

首先a[i]为i最后出现的位置,m[i]为数列中第1位到第i位最早的出现的不重复字串第一个字符的位置。

举个例子:(下标以1开始)

1 3 4 5 4时

a[2]=5

m[5]=2

懂了吗?没懂算了

所以 st[i]=max(st[i-1],last[x]+1)

Code:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int a[100005],m[100005],n,q,k,l,r;
int main(){
	cin>>n>>q;
	for(int i=1;i<=n;i++){
		cin>>k;
		m[i]=max(m[i-1],a[k]+1);
		a[k]=i;
	}
	for(int i=1;i<=q;i++){
		cin>>l>>r;
		if(m[r]<=l)cout<<"Yes\n";
		else cout<<"No\n";
	}
} 
相关推荐
jiang_changsheng9 分钟前
comfyui节点插件笔记总结新增加
人工智能·算法·计算机视觉·comfyui
TracyCoder1239 分钟前
LeetCode Hot100(7/100)—— 3. 无重复字符的最长子串
算法·leetcode
重生之我是Java开发战士13 分钟前
【优选算法】双指针法:移动0,复写0,快乐数,盛水最多的容器,有效三角形个数,二三四数之和
算法
321.。29 分钟前
深入理解 Linux 线程封装:从 pthread 到 C++ 面向对象实现
linux·开发语言·c++
EmbedLinX33 分钟前
Linux内核之文件系统:从VFS到实际存储的运作机制
linux·服务器·c语言·c++
客卿12343 分钟前
力扣二叉树简单题整理--(包含常用语法的讲解)
算法·leetcode·职场和发展
hrrrrb43 分钟前
【算法设计与分析】递归与分治策略
算法
We་ct1 小时前
LeetCode 28. 找出字符串中第一个匹配项的下标:两种实现与深度解析
前端·算法·leetcode·typescript
血小板要健康1 小时前
118. 杨辉三角,力扣
算法·leetcode·职场和发展
_OP_CHEN1 小时前
【算法基础篇】(五十一)组合数学入门:核心概念 + 4 种求组合数方法,带你快速熟悉组合问题!
c++·算法·蓝桥杯·排列组合·组合数学·组合数·acm/icpc