技术心得:区间检测(range)

简介: 技术心得:区间检测(range)

"

区间检测(range)

时间限制: 1 Sec 内存限制: 128 MB

题目描述

给定一个长度为n的序列,进行m次检测,每次检测某个区间中,是否有重复的数。

输入

第一行,两个整数n和m,表示序列中元素的个数以及需要检测的次数。

第二行n个元素,表示序列中的元素。

接下来m行,每行两个整数L和R(L≤R),表示需要检测的区间。

输出

对于每个询问,如果这个区间没有重复的数字,输出1,否则输0。

样例

5 2

1 2 3 4 1

1 4

1 5

1

0

提示

对于30%的数据,n和m的范围【1,500】;

对于50%的数据,n和m的范围【1,5000】;

对于80%的数据,n和m的范围【1,50000】,序列中的元素范围【0,105】;

对于100%的数据,n和m的范围【1,500000】,序列中的元素范围【0,109】

这就是题目了

这个我爆蛋了。。。

其实不难,但是我还是写的题目少了

这个题面非常的清晰,就不用再解释了

判断一个区间中有没有相同的数,把他给分割成为子问题,就是判断每一个数在这个区间内有没有相同的数

那么就很自然的想到维护每一个数前面和后面相同的数在什么位置就好了qwq

可是有必要吗awa

只用维护前面的就好了qwq

仔细想想就好了awa

如果这个区间里面有一个数重复了,那么肯定会有一个数前面一个和他相同的数在这个区间中awa

所以就方便多了qwq

pre【i】表示上一个值为A【i】的数出现的//代码效果参考:https://v.youku.com/v_show/id_XNjQwNjYzNjIyNA==.html

位置

题目等价于判断min(pre【L...R】)是否小于L

因为pre【1...L-1】显然是小于L的,所有可以直接判断min(pre【1...R】)是否小于L

快乐

code

#include

#define ll long long

using namespace std;

int n,m,a【5000001】,Max【500001】【30】;

map[span style=""color: rgba(0, 0, 255, 1)"">int,int

inline ll read()

{

char c=getchar();ll a=0,b=1;

for(;c[span style=""color: rgba(128, 0, 0, 1)"">'0'||c>'9';c=getchar())if(c=='-')b=-1;

for(;c>='0'&&c<='9';c=getchar())a=a*10+c-48;

return a*b;

}

ll ask(ll l,ll r)

{

ll k=log2(r-l+1);

return max(Max【l】【k】,Max【r-(1[k)+1】【k】);

}

void work()

{

int t=log2(n);

for(ll j=1;j<=t;j++)

{

for(ll i=1;i<=n-(1[j)+1;i++)

{

Max【i】【j】=max(Max【i】【j-1】,Max【i+(1[(j-1))】【j-1】);

}

}

}

int main()

{

n=read(),m=read();

for(int i=1;i<=n;i++)

{

int val=read();

Max【i】【0】=pre【val】;

pre【val】=i;

}

work();//代码效果参考:https://v.youku.com/v_show/id_XNjQwNjYzNzc4OA==.html

while(m--)

{

int l=read(),r=read();

if(ask(l,r)

else puts(""0"");

}

return 0;

}


"
image.png
相关文章
|
2月前
|
自然语言处理 数据可视化 API
优化采样参数提升大语言模型响应质量:深入分析温度、top_p、top_k和min_p的随机解码策略
本文详细解析了大语言模型(LLM)的采样策略及其关键参数,如温度和top_p。LLM基于输入提示生成下一个标记的概率分布,通过采样策略选择标记并附回输入,形成循环。文章介绍了对数概率(logprobs)、贪婪解码、温度参数调整、top-k与top-p采样等概念,并探讨了min-p采样这一新方法。通过调整这些参数,可以优化LLM输出的质量和创造性。最后,文章提供了实验性尝试的建议,帮助读者在特定任务中找到最佳参数配置。本文使用VLLM作为推理引擎,展示了Phi-3.5-mini-instruct模型的应用实例。
71 6
|
人工智能 测试技术
cf1653c通过操作让数组序列呈现某种规律 C. Differential Sorting
cf1653c通过操作让数组序列呈现某种规律 C. Differential Sorting
80 0
|
索引 Python
python 将纬度按照10°为区间进行划分,并筛选在不同区间内sss的个数
要求:python 将纬度(list类型,包含1500个数据,从-90°-90°随机排列)按照每10°进行区间划分,并根据下标索引筛选在每一个区间内,所包含的sss(海表盐度)个数。
python 将纬度按照10°为区间进行划分,并筛选在不同区间内sss的个数
LeetCode 5340. 统计有序矩阵中的负数 Count Negative Numbers in a Sorted Matrix
LeetCode 5340. 统计有序矩阵中的负数 Count Negative Numbers in a Sorted Matrix
CF1181B.Split a Number(贪心+高精度)
CF1181B.Split a Number(贪心+高精度)
94 0
|
关系型数据库 PostgreSQL
PostgreSQL 随机记录返回 - 300倍提速实践 (随机数组下标代替order by random())
标签 PostgreSQL , 数组 , 随机 , order by random() 背景 在业务系统中,有些场景会用到随机返回的功能,例如论坛,有很多帖子(比如有100万贴),有些是精华帖(比如有5万贴),为了让精华帖可以均衡的被访问,需要将5万贴随机的分页返回给用户。
1683 0
|
机器学习/深度学习 算法 计算机视觉