CF1550F Jumping Around

CF1550F Jumping Around

题意:

数轴上顺次有 n 个点a1<a2<⋯<an。a_1 < a_2 < \cdots < a_n。a1<a2<<an
有一只小青蛙,初始时在asa_sas处。小青蛙有两个参数:步长 d 和灵活程度 k。其中,步长 d 是确定的,而灵活程度 k 是可以调整的

小青蛙可以从某个点跳到另一个点。但这是有要求的:小青蛙能从 aia_iai跳到aja_jaj,当且仅当 d−k≤∣ai−aj∣≤d+kd-k\leq |a_i-a_j|\leq d+kdkaiajd+k

给定 a1,...,ana_1,...,a_na1,...,an和 d。你需要回答 q 次询问,每次询问给定一个一个下标 i和灵活程度 k ,你需要回答:此时的小青蛙能否跳到 ai?a_i?ai

保证1≤n,q≤2×105,1≤s,i≤n,1≤ai,d,k≤106,a1<a2<⋯<an。保证 1\leq n,q\leq 2\times 10^5,1\leq s,i\leq n,1\leq a_i,d,k\leq 10^6,a_1 < a_2 < \cdots < a_n 。1n,q2×1051s,in1ai,d,k106a1<a2<<an

题解:

我一开始想,满足这个式子d−k≤∣ai−aj∣≤d+kd-k\leq |a_i-a_j|\leq d+kdkaiajd+k就可以跳,那我直接查询区间[l,r]的相邻差值最大值和最小值,然后看是否符合式子。但是第二个样例就不对,随后我突然明白,u不能直接到达v,但是u可以先到达其他点x,再到达v。
我们现在换个思路想,当参数为k时,如果我们可以走到一个节点x,参数大于k时我们也可以走到该节点。那么我们就开始考虑对于每个节点,求出可以走到它的最小的k。
对于这个式子:
d−k≤∣ai−aj∣≤d+kd-k\leq |a_i-a_j|\leq d+kdkaiajd+k
−k≤∣ai−aj∣−d≤k-k\leq |a_i-a_j|-d\leq kkaiajdk
∣∣ai−aj∣−d∣≤k| |a_i-a_j|-d|\leq kaiajdk
也就是满足这个式子,点i就可以到达点j,我们可以将∣∣ai−aj∣−d∣| |a_i-a_j|-d|aiajd当作边权,如果点u可以到达点v,那么其路径上的最大值<=k,为了让u能到达v,我们希望路径上最大值最小,那不就是跑最小生成树
本题中边的数量是O(n2)O(n^2)O(n2),prim和kruskal都会超时,因此要用另一个最小生成树的算法boruvka算法。
这个算法不详细介绍了,详情见boruvka算法
算法的关键(也是复杂度与边权有关的地方)就是找最小边权的边,本题中边权是有性质的
现在我们要想∣∣ai−aj∣−d∣≤k| |a_i-a_j|-d|\leq kaiajdk值最小,设aia_iai在连通块内,aja_jaj在连通块外,那对于每个aia_iai,我们找aja_jaj最接近ai+da_i+dai+d或者ai−da_i-daid的点,然后取最小即可
具体操作为:
我们可以维护一个set,先存所有的a,然后对于一个连通块,枚举连通块内所有的点,把他们从set中删除,此时set中所有点都在这个连通块外。然后再枚举连通块内的所有点i,用set二分查找距离ai+da_i+dai+d或者ai−da_i-daid的点。直接在set上二分四次就找到了。最后再把所有点加回来。
二分找最小边权的复杂度是O(nlog n)
总复杂度是O(nlog2n)O(nlog^2n)O(nlog2n)
因为我们直到起点,把起点当作跟跑一边dfs,求出到其他点的路径上的最大值,如果询问中k大于这个最大值,就是Yes,否则就是No

代码:

#include <bits/stdc++.h>
#include <unordered_map>
#define debug(a, b) printf("%s = %d\n", a, b);
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int, int> PII;
clock_t startTime, endTime;
//Fe~Jozky
const ll INF_ll= 1e18;
const int INF_int= 0x3f3f3f3f;
void read(){};
template <typename _Tp, typename... _Tps> void read(_Tp& x, _Tps&... Ar)
{x= 0;char c= getchar();bool flag= 0;while (c < '0' || c > '9')flag|= (c == '-'), c= getchar();while (c >= '0' && c <= '9')x= (x << 3) + (x << 1) + (c ^ 48), c= getchar();if (flag)x= -x;read(Ar...);
}
template <typename T> inline void write(T x)
{if (x < 0) {x= ~(x - 1);putchar('-');}if (x > 9)write(x / 10);putchar(x % 10 + '0');
}
void rd_test()
{
#ifdef ONLINE_JUDGE
#elsestartTime = clock ();freopen("data.in", "r", stdin);
#endif
}
void Time_test()
{
#ifdef ONLINE_JUDGE
#elseendTime= clock();printf("\nRun Time:%lfs\n", (double)(endTime - startTime) / CLOCKS_PER_SEC);
#endif
}
const int maxn=2e6+9;
int n,m,q,s,d;
set<int>st;
int fa[maxn];
int a[maxn];
int id[maxn];
vector<PII>g[maxn];
int find(int x){if(fa[x]==x)return x;return fa[x]=find(fa[x]);
}
int getd(int x,int y){return abs(abs(x-y)-d);
}
void check(int &u,int &v,int x,int y){if(x==INF_int||y==INF_int)return ;if(getd(x,y)<getd(u,v)){u=x;v=y;}
}
struct node{int u,v,w;
}e1[maxn<<2];
vector<int>block[maxn];
void boruvka(){int m=n-1;while(m){for(int i=1;i<=n;i++)block[i].clear();for(int i=1;i<=n;i++)block[find(i)].push_back(i);int cnt=0;for(int i=1;i<=n;i++){if(find(i)==i){//找到一个连通块 int u=0,v=INF_int;for(int j=0;j<block[i].size();j++){st.erase(st.find(a[block[i][j]]));//删除连通块内元素 }for(int j=0;j<block[i].size();j++){check(u,v,a[block[i][j]],*st.lower_bound(a[block[i][j]]+d));check(u,v,a[block[i][j]],*(--st.lower_bound(a[block[i][j]]+d)));check(u,v,a[block[i][j]],*st.lower_bound(a[block[i][j]]-d));check(u,v,a[block[i][j]],*(--st.lower_bound(a[block[i][j]]-d)));} if(u!=0)//如果找到最小边,建最下生成树{e1[++cnt]=(node){id[u],id[v],getd(u,v)};} for(int j=0;j<block[i].size();j++)st.insert(a[block[i][j]]);}}for(int i=1;i<=cnt;i++){if(find(e1[i].u)!=find(e1[i].v)){m--;int u=e1[i].u;int v=e1[i].v;int w=e1[i].w;g[u].push_back({v,w});g[v].push_back({u,w});fa[find(u)]=find(v);}}}}
int ans[maxn];
void dfs(int u,int fa,int mx){ans[u]=mx;for(auto it:g[u]){int v=it.first;int w=it.second;if(v!=fa)dfs(v,u,max(mx,w));}
}
int main()
{//rd_test();cin>>n>>q>>s>>d;for(int i=1;i<=n;i++){cin>>a[i];block[i].push_back(i);st.insert(a[i]);fa[i]=i;id[a[i]]=i;}st.insert(-INF_int);st.insert(INF_int);boruvka();dfs(s,0,0);while(q--){int i,k;cin>>i>>k;if(ans[i]<=k)puts("Yes");else puts("No");}return 0;//Time_test();
}

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

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

相关文章

[COCI 2017-2018-2]-San

[COCI 2017-2018-2]-San san(1s64M) 游戏世界中有N个楼从左到右排列&#xff0c;从左到右编号为1到N&#xff0c;第i幢楼的高度为Hi,楼上的金币数为Gi,游戏可以从任意一个楼开始且包涵几步。每一步玩家可以从当前位置向右跳&#xff08;可以跳过一些楼&#xff09;但必须跳到…

领域模型架构 eShopOnWeb项目分析 上

一.概述本篇继续探讨web应用架构&#xff0c;讲基于DDD风格下最初的领域模型架构&#xff0c;不同于DDD风格下CQRS架构&#xff0c;二者架构主要区别是领域层的变化。 架构的演变是从领域模型到CQRS, 一开始DDD是用领域模型的分层架构&#xff0c;用单一的领域模型处理业务逻辑…

最小生成树--Boruvka算法

参考文章 介绍 第一次听说这个算法。。 对于最小生成树一定学过prim和krusal&#xff0c;prim复杂度是O(n2)或者O(elogn)O(n^2)或者O(elogn)O(n2)或者O(elogn),krusal复杂度是O(eloge)O(eloge)O(eloge)&#xff0c;这里介绍一下Boruvka算法 Boruvka算法解决某些特定问题非常好…

[NOIP2016]愤怒的小鸟(状压DP)

[NOIP2016]愤怒的小鸟&#xff08;状压DP&#xff09; 题目描述 输入输出格式 输入格式&#xff1a; 第一行包含一个正整数 T&#xff0c;表示游戏的关卡总数。 下面依次输入这 T个关卡的信息。每个关卡第一行包含两个非负整数 n,m&#xff0c;分别表示该关卡中的小猪数量和…

给 asp.net core 写一个简单的健康检查

给 asp.net core 写一个简单的健康检查Intro健康检查可以帮助我们知道应用的当前状态是不是处于良好状态&#xff0c;现在无论是 docker 还是 k8s 还是现在大多数的服务注册发现大多都提供了健康检查机制来检测应用的健康状态&#xff0c;如果应用本身就提供一个健康检查的机制…

Gym102832K. Ragdoll(CCPC长春)

Gym102832K. Ragdoll&#xff08;CCPC长春&#xff09; 题意&#xff1a; n个点&#xff0c;每个点都有自己的权值aia_iai​&#xff0c;一开始第i个点在第i个集合里。 如果一对点(i,j)是bad当且仅当满足i和j在同一个集合里&#xff0c;且gcd(ai,aj)ai⊕ajgcd(a_i,a_j)a_i⊕a…

LCA模板

LCA模板 此处只想贴个代码。 void dfs(int x,int father,int Dep) {dep[x]Dep;for (int i1;i<Log[Dep-1];i){Ln[x][i]Ln[ Ln[x][i-1] ][i-1];Ls[x][i]Ln[ Ln[x][i-1] ][i-1];}for (int i0;i<e[x].size;i)if (e[x][i].to!father){Ln[ e[x][i].to ][0]x;Ls[ e[x][i].to ]…

从阿里中台战略看企业IT架构转型之道(下)

此文是我阅读《企业IT架构转型之道》一书的学习笔记的下半部分&#xff0c;所有内容出自钟华老师的这本书。上半部分Part1~Part5请点击这里Part 6 异步与缓存原则异步化事务 > 核心是ACID柔性事务 > 基础是CAP理论和BASE理论&#xff0c;因为互联网应用最核心的需求是高可…

CF1543C. Need for Pink Slips

CF1543C. Need for Pink Slips 题意&#xff1a; 题解&#xff1a; 其实具体的计算方法在说明里面都写了&#xff1a;对于第一个数据&#xff1a; 0.2 0.2 0.6 0.2组成方案如下&#xff1a; 就是c和m如果大于v就减&#xff0c;小于v就变成0&#xff0c;到p直接停止 所以直接…

并查集(并茶几)

并查集&#xff08;并茶几&#xff09;的应用 一、What‘s that&#xff1f; 并查集是一种树型的数据结构&#xff0c;用于处理一些不相交集合&#xff08;Disjoint Sets&#xff09;的合并及查询问题。常常在使用中以森林来表示。 ——百度百科 二、How to uphold 0.我们的需…

从阿里中台战略看企业IT架构转型之道(上)

此文是我阅读《企业IT架构转型之道》一书的学习笔记的上半部分&#xff0c;所有内容出自钟华老师的这本书。零、为何阅读《企业IT架构转型之道》在加入X公司后&#xff0c;开始了微服务架构的实践&#xff0c;也开始了共享平台服务的建设&#xff0c;在这方面阿里巴巴的中台战略…

ML.NET机器学习、API容器化与Azure DevOps实践(四):持续集成与k8s持续部署

通过上文所介绍的内容&#xff0c;我们已经完成了RESTful API的开发&#xff0c;现在&#xff0c;就可以使用Azure DevOps来进行持续集成&#xff08;CI&#xff09;和k8s持续部署&#xff08;CD&#xff09;了。本文我会对使用Azure DevOps进行CI/CD的过程中需要注意的地方进行…

P3195 [HNOI2008]玩具装箱

P3195 [HNOI2008]玩具装箱 题意&#xff1a; n件玩具&#xff0c;第i件玩具经过压缩后的一维长度为CiC_iCi​,现在把玩具装入一维容器中&#xff0c;要求&#xff1a; 在一个一维容器中的玩具编号是连续的如果一个一维容器中有多个玩具&#xff0c;那么两件玩具之间要加入一…

卷积与莫比乌斯反演

卷积与莫比乌斯反演 目录 卷积与莫比乌斯反演 0前言 0.1前置技能 0.2问题的引入 1.简单定义 1.1数论函数的定义 1.2卷积的定义 1.3反演的基本形式 2.1莫比乌斯反演 3.1例题&#xff1a;【luogu-P2257 YY的GCD】 题目大意&#xff1a; solution1 solution2 0.前言 莫比…

ML.NET机器学习、API容器化与Azure DevOps实践(三):RESTful API

通过上文所述案例&#xff0c;我们已经选择了最优回归算法来预测学生的综合成绩&#xff0c;并且完成了基于训练数据集的预测模型训练。从实现上&#xff0c;训练好的模型被保存成一个ZIP文件&#xff0c;以便在其它项目中直接调用以完成机器学习的实践场景。在本文中&#xff…

Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)

Manthan, Codefest 19 (open for everyone, rated, Div. 1 Div. 2) 题号题目知识点AXORinacciBUniqueness尺取CMagic Grid构造DRestore Permutation思维线段树ELet Them Slide线段树思维FBits And PiecesGPolygonsHRed Blue Tree

杜教筛

杜教筛 1.概述 杜教筛是用以解决积性函数前缀和的算法。 在学习了莫比乌斯反演之后&#xff0c;杜教筛的过程就会显得简单而自然。 2.基本形式 对于积性函数&#xff0c;我们定义如下函数&#xff1a; 构造积性函数 &#xff0c;使得 显然 &#xff1a; 进一步转化&#xf…

CF1208D Restore Permutation

CF1208D Restore Permutation 题意&#xff1a; 现在有一个从1到n的一个全排列,但是你不知道这个排列到底是什么,但是你有一个sum[i],其中sum[i]表示∑j1i−1(aj<ai)?aj:0∑_{j1}^{i−1}(a_j<a_i)?a_j:0∑j1i−1​(aj​<ai​)?aj​:0,现在给你sum数组,让你求出这…

ML.NET机器学习、API容器化与Azure DevOps实践(二):案例

在上文中&#xff0c;我简单地介绍了机器学习以及ML.NET的相关知识&#xff0c;从本讲开始&#xff0c;我会基于一个简单的案例&#xff1a;学生成绩预测&#xff0c;来介绍使用ML.NET进行机器学习以及API部署的基本过程。本案例的数据来源为加州大学尔湾分校的机器学习公开样本…

业界萌新对斯坦纳树的小结

业界萌新对斯坦纳树的小结 0.简介 斯坦纳树问题是组合优化问题&#xff0c;与最小生成树相似&#xff0c;是最短网络的一种。最小生成树是在给定的点集和边中寻求最短网络使所有点连通。而最小斯坦纳树允许在给定点外增加额外的点&#xff0c;使生成的最短网络开销最小。 ——…