[POJ2942]Knights of the Round Table(点双+二分图判定——染色法)
建补图,是两个不仇恨的骑士连边,如果有环,则可以凑成一桌和谐的打麻将
不能直接缩点,因为直接缩点求的是连通分量,点双缩点只是把环缩起来
普通缩点 点双缩点


由图可知,左图中的缩法不符题意,而右图两个缩完后的点都满足题意
然后题中说必须要奇数个骑士参加会议,即找奇圈(有奇数个点的圈)
问题就转化成缩点后判断一个点是否在奇圈里,这就用到了点双的性质
点双连通分量有两个性质:1.如果该分量里有一个奇圈,那么其他所有点也必然在某个奇圈中;2.含有一个奇圈的充要条件是该分量不是二分图。
所以我们只需要缩完点之后枚举V-DCC判断是不是二分图,不是二分图就是奇圈
那么判断二分图用染色法判断即可
注意一个骑士不可以参加会议
这句话是自言自语: Lockey注意要检查变量名是否写对了
二分图定义:
一个无向图,使得顶点集V可以分割为两个互不相交的子集A,B,使得所有边两端分别属于两个子集A,B。
度娘解释
#include<iostream>
#include<cstdio>
#include<vector>
#include<cstring>
using namespace std;
int n,m,a[][],dfn[],low[],st[],ins[],num,v[],cnt,sp[],ok[],flag[],root;
vector<int>son[],spn[];
void tarjan(int x,int pre){
dfn[x]=low[x]=++num;
if(x==root&&son[x].size()==) spn[++cnt].push_back(x);
st[++st[]]=x;
ins[x]=;
for(int i=;i<son[x].size();i++){
int y=son[x][i];
if(y==pre) continue;
if(!dfn[y]){
tarjan(y,x);
low[x]=min(low[x],low[y]);
if(low[y]>=dfn[x]){
cnt++;
int w;
do{
w=st[st[]--];
ins[w]=;
spn[cnt].push_back(w);
}while(w!=y);
spn[cnt].push_back(x);
}
}
else low[x]=min(low[x],dfn[y]);
}
}
int dfs(int x,int pre,int loc){//是二分图返回0,是奇圈返回1
v[x]=v[pre]^;
//cout<<x<<" "<<v[x]<<endl;
for(int i=;i<son[x].size();i++){
int y=son[x][i];
//cout<<y<<" "<<" "<<flag[y]<<" "<<v[y]<<endl;
if(!flag[y]||y==pre) continue;
if(v[y]==-){
if(dfs(y,x,loc)) return ;
}
else if(v[y]==v[x]) return ;
}
return ;
} int main(){
scanf("%d%d",&n,&m);
while(n!=||m!=){
int x,y;
for(int i=;i<=m;i++){
scanf("%d%d",&x,&y);
a[x][y]=a[y][x]=;
}
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
if(a[i][j]||i==j) continue;
son[i].push_back(j);
}
}
for(int i=;i<=n;i++){
if(!dfn[i]) root=i,tarjan(i,);
}
memset(v,-,sizeof(v));
v[]=;
//cout<<cnt<<endl;
for(int i=;i<=cnt;i++){
if(spn[i].size()==) continue;
for(int j=;j<spn[i].size();j++) flag[spn[i][j]]=;
if(dfs(spn[i][],,i))
for(int j=;j<spn[i].size();j++)
ok[spn[i][j]]=;
for(int j=;j<spn[i].size();j++) flag[spn[i][j]]=,v[spn[i][j]]=-;
}
int ans=;
for(int i=;i<=n;i++) ans+=ok[i];
printf("%d\n",n-ans);
for(int i=;i<=n;i++){
dfn[i]=low[i]=;
st[i]=;
ins[i]=;
ok[i]=;
sp[i]=;
son[i].clear();
spn[i].clear();
}
st[]=;
memset(v,-,sizeof(v));
memset(a,,sizeof(a));
num=cnt=;
scanf("%d%d",&n,&m);
} }
[POJ2942]Knights of the Round Table(点双+二分图判定——染色法)的更多相关文章
- poj2942 Knights of the Round Table[点双+二分图染色]
首先转化条件,把无仇恨的人连边,然后转化成了求有哪些点不在任何一个奇环中. 一个奇环肯定是一个点双,所以想到处理出所有点双,但是也可能有的点双是一个偶环,有的可能是偶环和奇环混杂,不好判. 考察奇环性 ...
- 【POJ 2942】Knights of the Round Table(双联通分量+染色判奇环)
[POJ 2942]Knights of the Round Table(双联通分量+染色判奇环) Time Limit: 7000MS Memory Limit: 65536K Total Su ...
- POJ2942 Knights of the Round Table[点双连通分量|二分图染色|补图]
Knights of the Round Table Time Limit: 7000MS Memory Limit: 65536K Total Submissions: 12439 Acce ...
- POJ2942 Knights of the Round Table 点双连通分量 二分图判定
题目大意 有N个骑士,给出某些骑士之间的仇恨关系,每次开会时会选一些骑士开,骑士们会围坐在一个圆桌旁.一次会议能够顺利举行,要满足两个条件:1.任意相互憎恨的两个骑士不能相邻.2.开会人数为大于2的奇 ...
- [POJ2942]:Knights of the Round Table(塔尖+二分图染色法)
题目传送门 题目描述 亚瑟王要在圆桌上召开骑士会议,为了不引发骑士之间的冲突,并且能够让会议的议题有令人满意的结果,每次开会前都必须对出席会议的骑士有如下要求: .相互憎恨的两个骑士不能坐在直接相邻的 ...
- POJ2942 Knights of the Round Table 点双连通分量,逆图,奇圈
题目链接: poj2942 题意: 有n个人,能够开多场圆桌会议 这n个人中,有m对人有仇视的关系,相互仇视的两人坐在相邻的位置 且每场圆桌会议的人数仅仅能为奇书 问有多少人不能參加 解题思路: 首先 ...
- 【POJ】2942 Knights of the Round Table(双连通分量)
http://poj.org/problem?id=2942 各种逗.... 翻译白书上有:看了白书和网上的标程,学习了..orz. 双连通分量就是先找出割点,然后用个栈在找出割点前维护子树,最后如果 ...
- 「题解」:[POJ2942]Knights of the Round Table
问题 E: Knights of the Round Table 时间限制: 1 Sec 内存限制: 256 MB 题面 题目描述 作为一名骑士是一个非常有吸引力的职业:寻找圣杯,拯救遇难的少女,与 ...
- Knights of the Round Table-POJ2942(双连通分量+交叉染色)
Knights of the Round Table Description Being a knight is a very attractive career: searching for the ...
随机推荐
- SqlServer删除复制监视器中无效的发布名称
原文:SqlServer删除复制监视器中无效的发布名称 在服务器复制监视器中有一个发布名称,因为该发布订阅已经删除. ReportServerTempDB只有一个发布,已无效,打算删除. --直接删除 ...
- uwp之拍照(使用后置摄像头)
参考:wp8.1之拍照(获取焦点,使用后置摄像头) uwp开启摄像头要借助CaptureElement呈现来自捕获设备(如照相机或网络摄像机)的流.今天讲讲如何打开摄像头,获取焦点,以及拍照.废话不多 ...
- Android零基础入门第83节:Activity间数据传递方法汇总
在Activity间传递的数据一般比较简单,但是有时候实际开发中也会传一些比较复杂的数据,本节一起来学习更多Activity间数据的传递. 一.常用数据类型 在前面几节我们只学习了一些常用类型的数据传 ...
- VC 调用 MinGW 生成的dll good
首先,如果dll 中导出了C++的类,那么就不要折腾了.不同的编译器编译出来的C++代码是不保证通用的.如果dll中只是一些C 函数,那么是可以互相调用的. MinGW 生成dll时即使生成了 .a ...
- Delphi 与 VC 共享接口和对象
我经常会用 Delphi 写一些工具和应用,为了扩展方便,大部分都会做成插件形式. 迫于某些原因,我的插件不得不用其他开发工具来完成,比如 VC. 于是有个大问题需要解决:如何让 D 和 VC 互相通 ...
- WordPress中.user.ini 权限问题
安装完WordPress在给予权限或者删除的时候可能会收到下面的提示. [root@localhost default]# chmod -R 755 /home/wwwroot chmod: 更改&q ...
- VS2013编译Qt5.6.0静态库,并提供了百度云下载(乌合之众)good
获取qt5.6.0源码包 直接去www.qt.io下载就好了,这里就不详细说了. 这里是我已经编译好的** 链接:http://pan.baidu.com/s/1pLb6wVT 密码: ak7y ** ...
- jqGrid使用经验分享(一)——jqGrid简单使用、json格式和jsonReader介绍
广大的读者朋友们大家好,很高兴又可以在博客中和大家分享我的开发经验了. 此次,我准备向大家介绍一个非常好用的jQuery表格插件——jqGrid. 如果您在实际项目中遇到web端表格展示功能的需求,又 ...
- Zookeeper详解-Cli(五)
ZooKeeper命令行界面(CLI)用于与ZooKeeper集合进行交互以进行开发.它有助于调试和解决不同的选项. 要执行ZooKeeper CLI操作,首先打开ZooKeeper服务器(“bin/ ...
- Django框架之前端渲染-模板层
Django 模板层 Django 模板层 前后端数据传递 (1) 后端朝前端页面传递数据的方式: # 将当前所在的名称空间中的名字全部传递给前端页面 # 第一种 return render( ...