HDU 2860 并查集
http://acm.hdu.edu.cn/showproblem.php?pid=2860
n个旅,k个兵,m条指令
AP 让战斗力为x的加入y旅
MG x旅y旅合并为x旅
GT 报告x旅的战斗力
几个需要注意的小问题是:已经被合并过的不能再参加合并这样就简化了并查集本身的复杂度只存在一层继承关系
一道简单的并查集题目,一开始不知道什么情况总是PE,格式上找不到错23333
后来参考了潘大神的代码,原来是最后回车的位置粗了偏擦23333
#include<stdio.h>
#define inf 0x3f3f3f3f
int par[];
int miner[];
int min(int a,int b)
{
if(a>b){return b;}
else return a;
}
void atfirst(int n)
{
int i;
for(i=;i<n;i++)
{
par[i]=i;
miner[i]=inf;
}
}
int find(int x)
{
return x!=par[x]?par[x]=find(par[x]):x;
}
int main()
{
int i,k,n,m;
int r,c;
freopen("in.txt","r",stdin);
freopen("out.txt","w",stdout);
while(scanf("%d%d%d",&n,&k,&m)!=EOF)
{
atfirst(n);
for(i=;i<=k;i++)
{
scanf("%d%d",&r,&c);
miner[c]=min(r,miner[c]);
}
for(i=;i<=m;i++)
{
char donser[];
scanf("%s",&donser);
if(donser[]=='A')
{
scanf("%d%d",&r,&c);
if(par[c]!=c){printf("Reject\n");continue;}
miner[c]=min(r,miner[c]);
printf("Accept\n");
}
if(donser[]=='M')
{
scanf("%d%d",&r,&c);
if(r==c){printf("Reject\n");continue;}
if(par[r]==r&&par[c]==c)
{
par[c]=r;
miner[r]=min(miner[r],miner[c]);
printf("Accept\n");
}
else printf("Reject\n");
}
if(donser[]=='G')
{
scanf("%d",&r);
if(par[r]==r&&miner[r]!=inf)
printf("Lowest rate: %d.\n",miner[r]);
else if(par[r]==r&&miner[r]==inf)
printf("Company %d is empty.\n",r);
else
{
printf("Company %d is a part of company %d.\n",r,find(r));
}
}
}
printf("\n");
}
return ;
}
HDU 2860 并查集的更多相关文章
- hdu 4514 并查集+树形dp
湫湫系列故事——设计风景线 Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Tot ...
- HDU 3926 并查集 图同构简单判断 STL
给出两个图,问你是不是同构的... 直接通过并查集建图,暴力用SET判断下子节点个数就行了. /** @Date : 2017-09-22 16:13:42 * @FileName: HDU 3926 ...
- HDU 4496 并查集 逆向思维
给你n个点m条边,保证已经是个连通图,问每次按顺序去掉给定的一条边,当前的连通块数量. 与其正过来思考当前这边会不会是桥,不如倒过来在n个点即n个连通块下建图,检查其连通性,就能知道个数了 /** @ ...
- HDU 1232 并查集/dfs
原题: http://acm.hdu.edu.cn/showproblem.php?pid=1232 我的第一道并查集题目,刚刚学会,我是照着<啊哈算法>这本书学会的,感觉非常通俗易懂,另 ...
- hdu 1198 (并查集 or dfs) Farm Irrigation
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1198 有题目图11种土地块,块中的绿色线条为土地块中修好的水渠,现在一片土地由上述的各种土地块组成,需要浇 ...
- hdu 1598 (并查集加贪心) 速度与激情
题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1598 一道带有贪心思想的并查集 所以说像二分,贪心这类基础的要掌握的很扎实才行. 用结构体数组储存公 ...
- hdu 4496(并查集)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4496. 思路:简单并查集应用,从后往前算就可以了. #include<iostream> ...
- 2015多校第6场 HDU 5361 并查集,最短路
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5361 题意:有n个点1-n, 每个点到相邻点的距离是1,然后每个点可以通过花费c[i]的钱从i点走到距 ...
- HDU 1856 并查集
http://acm.hdu.edu.cn/showproblem.php?pid=1856 More is better Time Limit: 5000/1000 MS (Java/Others) ...
随机推荐
- win8启动文件夹
进入C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp.鼠标右键选中粘贴,将软件快捷方式粘贴到启动目录 进入文件夹时路径可能是C: ...
- easyUI 树的上下文菜单
一.属性:onContextMenu onContextMenu: function(e,node){ e.preventDefault(); $(this).tree('select',node.t ...
- 9月13日JavaScript语句循环(100以备奇偶数、100以内与7先关的数、100以内整数的和、10以内阶乘、乘法口诀、篮球弹起高度、64格子放东西)
3.循环 循环是操作某一个功能(执行某段代码). ①循环四要素: a 循环初始值 b 循环的条件 c 循环状态 d 循环体 ②for循环 a 穷举:把所有的可能性的都一一列出来. b 迭代:每次循环都 ...
- AssetBundle in Unity 5.0
http://forum.unity3d.com/threads/new-assetbundle-build-system-in-unity-5-0.293975/
- ecshop 变量表
get_goods_info($goods_id) 商品详情 get_sales_count($goods_id) 商品销量 get_promote_goods() 参与促销商品 Mobile
- SVN合并操作实践
大家都知道,SVN是很多公司管理代码的版本控制工具,当分支越来越多,版本迭代越来越频繁的时候,经常会出现代码冲突的头疼事儿,这里讲一下鲨鱼遇到过关于代码版本控制的一些事,最后做个小例子,看图描述. 为 ...
- osharp3 操作日志之数据日志 控制增强
osharp3 原来的数据日志,有配置文件中有这总开关,DataLoggingEnabled,原来的程序是,这个总开关关了,就无法记录数据日志了,,如果开了,,他不管记录不记录数据日志,系统都会存数据 ...
- thinkphp- 许愿墙-1
控制器的方法, 要显示的模板默认的跟方法名相同. 也可以不同, 但应该 仍然是对应文件夹下的html模板文件: $this->display('其他的模板html文件名, 不用加html扩展名' ...
- 在linux下运行apt-get update 时,报错/var/lib/apt/lists/lock
在运行apt-get update 时,报下面的错误: E: 无法获得锁 /var/lib/apt/lists/lock - open (11: Resource temporarily unavai ...
- 阿里云9折推荐码:0LGVW2
阿里云9折推荐码:0LGVW2,第一次购买云服务器或云数据库可享受原价9折优惠.