[COCI2017-2018#5] Pictionary(并查集+dfs)

贼ex的一道,卡了本仙女整整7个小时orz
在这里插入图片描述
思路容易理解,but码力very重要orz
我愿意花五毛钱提升我的码力,换个脑子也行,不换脸这张脸生得俊俏
luogu传送door

题目

在宇宙一个不为人知的地方,有一个星球,上面有一个国家,只有数学家居住。 在这个国家有n个数学家,有趣的是,每个数学家都住在自己的城市,且城市间无道路相连,因为他们可以在线交流。当然,城市有从1到n的编号。

一位数学家决定用手机发论文,而手机将“不言而喻”自动更正成了“猜谜游戏”。 不久之后,这个国家就发现了猜谜游戏。他们想要见面一起玩,于是这个国家就开始了修路工程。 道路修建会持续m天。对于第i天,若gcd(a,b)=m−i+1,则a和b城市间会修一条路。

由于数学家们忙于建筑工作,请你来确定一对数学家最早什么时候能凑到一起玩。

输入输出格式
输入格式
第一行有三个正整数n,m,q,表示城市数量、修路持续天数、询问数量。 接下来q行,每行有两个正整数a,b,表示询问a和b两个城市的数学家最早什么时候能在一起玩。

输出格式
输出q行,第i行有一个正整数,表示第i次询问的结果

说明
数据范围:
对于40%的数据:n≤4000,q≤10 ^5

对于全部数据:
1≤n,q≤10^5

1≤m≤n1≤m≤n

样例1解释: 在第一天,(3,6)(3,6)之间修了一条路,因此第二次询问输出1
在第二天,(2,4),(2,6),(2,8),(4,6),(6,8)(2,4),(2,6),(2,8),(4,6),(6,8)之间都修了一条路,此时44和88号城市连通,第三次询问输出2
在第三天,所有编号互质的城市之间都修了路,2和5号城市在此时连通,第一次询问输出1

样例2解释: 在第二天,(20,15)之间修了一条路
第四天,(15,9)之间修了一条路
所以20和9号城市在第四天连通,输出4

题解

我看了luogu题解,发现根本没有人跟宝宝是一个做法,当时,我的妈呀!
俺内心慌得一批,但是我在这条不归路上继续走了下去,误入歧途啊
七个小时终于把这个江山打下来了在这里插入图片描述
肯定很好想,问这两个城市有没有相通,肯定是我们的并查集大哥,这个不用多说!
而且1与任何数都互质,那么在最后一天施完工后肯定所有城市都是互通的,
这就是一棵赤裸裸的树

我们真正要解决的就是这两个城市在第几天成为了一个集合

帅气的我的实现是先预处理每一天,哪些城市会进行施工相通,边处理,边并查集,这样的话就不用把所有的边全部得到后再sort再并查集。
因为从m到1循环的话,i,j之间没路时,这天就是最早的 ,

PS:并查集的unionSet一定要用优化的启发式,不然就等着TLE回家找妈妈吧!
反正我是把长城都哭淹了!我们在进行unionSet时顺便建个有向边,
一定是爸爸之间建边,又哭了orz

接着就是dfs,不一定是从1开始,可以用循环找根节点f[i]==i,哭了哭了。
dfs处理每一个点的深度,而且可以保证每个点的入度不会大于1,在处理深度的同时,把u,v两点第几天相同的也记录下来,用vector可以办到

最后就是爬树,妙啊!妙啊!暴力lca都行的老铁,
因为每个点都只有一个爸爸 (诶)
所以这棵树也是唯一的,路径唯一的,
我们就在线操作,x,y用一个Max记录x和y在往上爬的时候路径的最大值

以上听起来是不是很简单啊woo~

代码实现

瞅瞅吧!七个小时的改了n遍,长得惨不忍睹啊!这浓缩的都是精华啊!
还有rank标记数组,rank是关键字,又哭了哭了orz,泪腺炸了

#include <cstdio>
#include <vector>
#include <iostream>
using namespace std;
#define MAXN 100005
#define LL long long
struct node {int v, w;node () {}node ( int A, int B ) {v = A;w = B;}
}depth[MAXN];
int n, m, q, cnt;
int f[MAXN];
int ran[MAXN];
vector < node > tree[MAXN];
void makeSet () {for ( int i = 1;i <= n;i ++ )f[i] = i;
}
int findSet ( int x ) {while ( x != f[x] ) x = f[x];return x;
}
void unionSet ( int x, int y, int w ) {int u = findSet( x ); int v = findSet( y );if ( u == v ) return;if ( ran[u] > ran[v] ) {f[v] = u;tree[u].push_back ( node ( v, w ) );}else {f[u] = v;if( ran[u] == ran[v] )ran[v] ++;tree[v].push_back ( node ( u, w ) );}
}
void dfs ( int x, int dep, int val ) {if ( depth[x].v ) return;depth[x].v = dep;depth[x].w = val;for ( int i = 0;i < tree[x].size();i ++ ) {int v = tree[x][i].v, w = tree[x][i].w;dfs ( v, dep + 1, w );}
}
int Max = 0;
void lca ( int x, int y ) {while ( depth[x].v > depth[y].v ) {Max = max ( depth[x].w, Max );x = f[x];}while ( depth[y].v > depth[x].v ) {Max = max ( depth[y].w, Max );y = f[y];}while ( x != y ) {Max = max ( depth[x].w, Max );Max = max ( depth[y].w, Max );x = f[x];y = f[y];}
}
int main() {scanf ( "%d %d %d", &n, &m, &q );makeSet ();for ( int i = m;i >= 1;i -- )for ( int j = i * 2;j <= n;j += i )if ( findSet ( j - i ) != findSet ( j ) )unionSet ( j - i, j, m - i + 1 );for ( int i = 1;i <= n;i ++ )if ( f[i] == i ) {dfs ( i, 1, 0 );break;}for ( int i = 1;i <= q;i ++ ) {int a, b;scanf ( "%d %d", &a, &b );Max = 0; lca ( a, b );printf ( "%d\n", Max );	}return 0;
}

把这道题A(≧▽≦)/啦啦啦
在这里插入图片描述在这里插入图片描述
好了,像打了鸡血吃兴奋剂一样,有任何代码,思路不懂得欢迎留言,欢迎欢迎热烈欢迎,我们不卖假,诚信营业,做出世界前五百强!byebye~不要太想帅气又多金的我!

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

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

相关文章

Docker最全教程——从理论到实战(九)

在本系列教程中&#xff0c;笔者希望将必要的知识点围绕理论、流程&#xff08;工作流程&#xff09;、方法、实践来进行讲解&#xff0c;而不是单纯的为讲解知识点而进行讲解。也就是说&#xff0c;笔者希望能够让大家将理论、知识、思想和指导应用到工作的实际场景和实践之中…

[2019CSP多校联赛普及组第五周] 调度CPU (贪心)

来来来&#xff0c;走过路过不要错过题目题解代码实现1代码实现2题目 ⼩Y同学有⼀块超级CPU&#xff0c;它有两个超级核⼼A和B。 A核⼼可以同时处理多项任务&#xff0c;每项任务处理时间为x&#xff0c;B核⼼只能同时处理⼀项任务&#xff0c;每项任务处理时间为y。 这⼀天…

NumSharp v0.6.1 科学计算库发布,支持标量和隐式转换

NumSharp&#xff08;Numerical .NET&#xff09;可以说是C&#xff03;中的科学计算库。 它是用C&#xff03;编写的&#xff0c;符合.netstandard 2.0库标准。 它的目标是让.NET开发人员使用NumPy的语法编写机器学习代码&#xff0c;从而最大限度地借鉴现有大量在python代码的…

[Luogu2279][HNOI2003] 消防局的设立

文章目录题目法一&#xff1a;树上DP思路代码实现法二&#xff1a;贪心 搜索思路代码实现题目 2020年&#xff0c;人类在火星上建立了一个庞大的基地群&#xff0c;总共有n个基地。起初为了节约材料&#xff0c;人类只修建了n-1条道路来连接这些基地&#xff0c;并且每两个基…

dnSpy 强大的.Net反编译软件

一说起.net的反编译软件&#xff0c;大家首先想到的就是Reflector&#xff0c;ILSpy&#xff0c;dotPeek等等。而dnSpy同样是一款优秀的反编译软件&#xff0c;同时它是开源免费的。官方的描述是: dnSpy是一个调试器和.NET组件编辑器。 即使您没有任何可用的源代码&#xff0c;…

小奇探险

文章目录题目题解代码实现题目 小奇去遗迹探险&#xff0c;遗迹里有N个宝箱&#xff0c;有的装满了珠宝&#xff0c;有的装着废品。 小奇有地图&#xff0c;所以它知道每一个宝箱的价值&#xff0c;但是它不喜欢走回头路&#xff0c;所以要按顺序拿这N个宝箱中的若干个。 拿宝…

基于Asp.Net Core打造轻量级内部服务治理RPC(二 远程服务设计)

紧接上一篇《基于Asp.Net Core打造轻量级内部服务治理RPC(一)》文章。本文主要讲解基于Asp.Net Core的远程服务设计和实现。在上一篇中讲过,服务提供者提供的服务实际上就是一个Controller&#xff0c;那么是否在该程序中&#xff0c;服务都按照Asp.Net Core 中的Web Api的方式…

[NOIP 2009 提高组]最优贸易

勤劳的一更题目题解代码实现题目 C国有 n个大城市和 m 条道路&#xff0c;每条道路连接这n个城市中的某两个城市。任意两个城市之间最多只有一条道路直接相连。这 m 条道路中有一部分为单向通行的道路&#xff0c;一部分为双向通行的道路&#xff0c;双向通行的道路在统计条数…

Azure Service Fabric Mesh:一个构建任务关键型微服务的平台

本文要点Azure Service Fabric Mesh&#xff08;目前处于预览阶段&#xff09;是一个完全托管的服务&#xff0c;它使你可以使用“无服务器”方法构建、部署和管理由运行在容器中的多语言服务组成的应用程序。Azure Service Fabric Mesh 通过使用 Envoy Proxy 构建的软件定义网…

P3265 [JLOI2015]装备购买

题目描述&#xff1a; 给N个整数向量&#xff0c;每个向量带权值&#xff0c;求权值和最小的线性基 题解&#xff1a; 按权值v从小->大排序&#xff0c;依次插入线性基。整数线性基的思想类似&#xff0c;只是此时“消去”不能直接xor完成&#xff0c;需要类似高斯消元一样…

Surging1.0发布在即,.NET开发者们,你们还在等什么?

开源&#xff0c;是近三十年来互联网经久不衰的话题。它不仅仅是一种技术分享的形态&#xff0c;更是一种开放&#xff0c;包容&#xff0c;互利共赢的互联网精神。 不到30年前&#xff0c;大神林纳德托瓦兹&#xff0c;在赫尔辛基大学实验室里&#xff0c;开发出了第一个版本的…

[SDOI2016]排列计数 (错排数概念 + 递推公式【附带证明】)

辛勤二更题目题解错排数概念错排数递推公式及其证明代码实现这种题做的时候&#xff1a; 做完后&#xff1a;正常这就是生活&#xff0c;我们要学会习惯 题目 求有多少种长度为 n 的序列 A&#xff0c;满足以下条件&#xff1a; 1 ~ n 这 n 个数在序列中各出现了一次 若第 i …

失配树(border树)

4和6没有border关系 举例子&#xff1a; 当i 3时&#xff0c;j fa[i-1] fa[2] 0 s[j1] s[1] a s[3] 所以把i 3点的父亲设为j1 1 P5829 [模板]失配树

魔方俱乐部

爆肝感动三更题目思路90分代码&#xff08;MLE&#xff09;题解代码实现题目 fateice 来到了魔方俱乐部旅行。 魔方俱乐部有N个分部&#xff0c;每个分部均有且仅有一个虫洞&#xff0c;但是这虫洞只能通往一个分部。 每个分部有一个 orzFang 价值&#xff0c;第i个分部的 or…

模板:最大匹配

文章目录前言代码前言 匈牙利算法 可以解决的问题&#xff1a; &#xff08;原谅我的偷懒&#xff09; &#xff08;原谅我的水文&#xff09; 代码 #include<bits/stdc.h> using namespace std; #define ll long long const int N3e5100; const int mod1e97; int n,…

Stack Overflow 监控系统内部架构初探

Stack Exchange 架构主管 Nick Craver 在最近的一篇文章中介绍了他们的监控系统。他在文章中讨论了监控策略背后的理念和动机&#xff0c;并介绍了他们的工具集——主要是 Bosun、Grafana 和 Opserver。Stack Overflow 及其姐妹站点 Stack Exchange 运行在.NET 和 MS SQL Serve…

P5829 【模板】失配树

P5829 【模板】失配树 题目&#xff1a; 题解&#xff1a; 参考题解 我们先想一个问题&#xff1a;如何求出一个字符串的所有border&#xff1f; 如果一个字符串既是 S的前缀又是 S 的后缀&#xff0c;那么我们把 SS 自己平移一下就可以前后重合&#xff0c;然后我们就可以继…

[JLOI2015]战争调度

文章目录题目题解代码实现题目 脸哥最近来到了一个神奇的王国&#xff0c;王国里的公民每个公民有两个下属或者没有下属&#xff0c;这种关系刚好组成一个 n 层的完全二叉树。 公民 i 的下属是 2 * i 和 2 * i 1。最下层的公民即叶子节点的公民是平民&#xff0c; 平民没有下…

使用PerfView监测.NET程序性能(一):Event Trace for Windows

前言&#xff1a;在日常项目开发中&#xff0c;我们时不时会遇到程序占用了很高CPU的情况&#xff0c;可能是程序里某些未经优化的代码或者Bug&#xff0c;或者是程序运行压力太大。无论是什么原因&#xff0c;我们总希望能看到到底是哪个方法占用了如此高的CPU。微软为我们提供…

【用学校抄作业带你走进可持久化线段树(主席树)】可持久化线段树概念+全套模板+例题入门:[福利]可持久化线段树)

我似乎很少写这种算法博客可持久化线段树概念概念介绍&#xff08;类比帮助理解&#xff09;简单分析一下时间和空间复杂度&#xff08;内容池&#xff09;模板结构体变量建树模板单点修改模板单点查询模板区间修改模板&#xff08;pushup&#xff09;区间修改模板&#xff08;…