[wikioi]关押罪犯
错误半天还是因为并查集写错了。写错的地方是合并X和Y的时候,应该把FX挂到FY上去,而不是把X挂到Y上或FY上去,因为FX和FY下面有一树别的节点。 http://www.nocow.cn/index.php/%E5%B9%B6%E6%9F%A5%E9%9B%86
加强印象,仔细看图:

本题的思路有两种,一是求最大值最小,而已二分+BFS来做,但效率较低。更好的做法是贪心+并查集。先按照怨念排序,然后从大到小判断是否有冲突。
判断冲突的时候用了个巧妙的方法,就是A和B不能放在一组,那么设A的补集为!A,B的补集!B,那么merge(A, !B) 且merge(B, !A),这样当有A不能和B在一起,C不能和B在一起时,由于A和C都在!B一组里了,merge时会冲突。i的补集用i+n来表示,所以开2N的数组。
#include <cstdio>
#include <iostream>
#include <algorithm>
#include <memory.h>
#define MAX(a, b) a>b?a:b
#define LEN_N 20005
#define LEN_M 100005
using namespace std; struct Conflict
{
int a;
int b;
int val;
}; int N;
int M;
int father[LEN_N*2];
Conflict edges[LEN_M]; bool comp(Conflict a, Conflict b)
{
return a.val > b.val;
} int find(int i) {
if (father[i] != i) {
father[i] = find(father[i]);
}
return father[i];
} void merge(int i, int j) {
father[find(i)] = find(j);
} void init()
{
memset(edges, 0, sizeof(edges));
memset(father, 0, sizeof(father));
scanf("%d%d", &N, &M);
for (int i = 0; i < M; i++) {
scanf("%d%d%d", &edges[i].a, &edges[i].b, &edges[i].val);
}
for (int i =1; i <= N*2; i++) {
father[i] = i;
}
} int main()
{
init();
sort(edges, edges+M, comp);
int ans = 0;
for (int i = 0; i < M; i++) {
int a = edges[i].a;
int b = edges[i].b;
if (find(a) == find(b)) {
// conflict
ans = edges[i].val;
break;
}
merge(a, b+N);
merge(b, a+N);
} printf("%d\n", ans);
return 0;
}
[wikioi]关押罪犯的更多相关文章
- 并查集补集作法   codevs 1069 关押罪犯
		
1069 关押罪犯 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description ...
 - NOIP2010提高组 关押罪犯   -SilverN
		
(洛谷P1525) 题目描述 S 城现有两座监狱,一共关押着N 名罪犯,编号分别为1~N.他们之间的关系自然也极不和谐.很多罪犯之间甚至积怨已久,如果客观条件具备则随时可能爆发冲突.我们用“怨气值”( ...
 - [NOIP2010] 提高组 洛谷P1525 关押罪犯
		
刚才做并查集想到了这道以前做的题,干脆一并放上来 题目描述 S 城现有两座监狱,一共关押着N 名罪犯,编号分别为1~N.他们之间的关系自然也极不和谐.很多罪犯之间甚至积怨已久,如果客观条件具备则随时可 ...
 - Codevs 1069 关押罪犯  2010年NOIP全国联赛提高组
		
1069 关押罪犯 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description S 城现有两座监狱,一共 ...
 - NOIP2010提高组] CODEVS 1069 关押罪犯(并查集)
		
这道这么简单的题目还写了这么久.. 将每个会发生冲突的两人的怒气进行排序,然后从怒气大到小,将两个人放到不同监狱中.假如两人都已经被放置且在同一监狱,这就是答案. ------------------ ...
 - codevs 1069 关押罪犯
		
提交地址:http://codevs.cn/problem/1069/ 1069 关押罪犯 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻 ...
 - Luogu P1892 P1525 团伙 关押罪犯
		
(怎么都是抓罪犯 怪不得写法差不多) 团伙 关押罪犯 并查集.以"敌人的敌人是朋友"的思路来处理.所以增加一个e/E数组来存储敌人. 关押罪犯还用到了贪心的思路.将冲突值从大到小排 ...
 - 洛谷 P1525 关押罪犯
		
题目链接 https://www.luogu.org/problemnew/show/P1525 题目描述 S城现有两座监狱,一共关押着N名罪犯,编号分别为1−N.他们之间的关系自然也极不和谐.很多罪 ...
 - Luogu 1525 【NOIP2010】关押罪犯 (贪心,并查集)
		
Luogu 1525 [NOIP2010]关押罪犯 (贪心,并查集) Description S城现有两座监狱,一共关押着N名罪犯,编号分别为1~N.他们之间的关系自然也极不和谐.很多罪犯之间甚至积怨 ...
 
随机推荐
- 3d max地形建造
			
这里来记录一下max里面建造一个地形. 1.创建一个平面,调节平面的属性,包括长宽,和分段 2.然后建造一个道路 然后选择样条线工具,调节线条的轮廓. 3.使用合并工具,将线条和地面进行合并成为一个物 ...
 - wap上传图片跨域发送post请求
			
wap和接口交互是跨域请求,一般只能通过Jsonp来进行数据的吞吐,然而jsonp只是GET请求,不能发送post请求,所以会对项目需求有所限制. 需求:wap跨域通过接口上传图片. 条件:接口是C# ...
 - android 中在CMD中查看sqlite
			
今天第一次学习Sqlite,在代码中执行了sql,但是不知道在上面地方才能直观的查看sqlite中的数据,下面是查看资料后的找到的查看方法: 通过上述可以从cmd进入数据库查看原文地址:http:// ...
 - PeekMessage
			
PeekMessage是一个Windows API函数.该函数为一个消息检查线程消息队列,并将该消息(如果存在)放于指定的结构. 1 语法 BOOL PeekMessage( LPMSG IpMsg, ...
 - TPL(Task Parallel Library)多线程、并发功能
			
The Task Parallel Library (TPL) is a set of public types and APIs in the System.Threading and System ...
 - C++ Dialog Box Command IDs
			
#define IDOK 1 #define IDCANCEL 2 #define IDABORT 3 #define IDRETRY 4 #define IDIGNORE 5 #define IDY ...
 - ios开发,地图标注聚集。搜索标注title功能
			
最近在做地图功能,要实现的就是地图标注聚集,还有搜索地图 地图标注通常都是大头针.如果地图缩小到一定范围的时候,会显示密密麻麻的大头针.这样会显的难看 所以设计了一定区域范围内的大头针,缩小的时候给聚 ...
 - @property在内存管理中的参数问题
			
// // Created by wanghy on 15/8/14. // // /* retain : release旧值,retain新值(用于OC对象),要配合nonatomic使用. ass ...
 - C# 中使用win32函数 GetScrollInfo返回false 返回引用全是零的问题
			
最近做一个项目要获得ScrollBar的位置,因为.net找不到此类功能,只好用MFC中的函数了,GetScrollPos只返回listview顶部的位置,此时我找到了GetScrollInfo,觉得 ...
 - java web-----servelet
			
1,定义servlet: 2,servlet生命周期: 3,HttpServlet常用方法: 4,servlet常用接口: 一,servlet定义: servlet是一个继承HttpServlet类的 ...