首先转化条件,把无仇恨的人连边,然后转化成了求有哪些点不在任何一个奇环中。

一个奇环肯定是一个点双,所以想到处理出所有点双,但是也可能有的点双是一个偶环,有的可能是偶环和奇环混杂,不好判。

考察奇环性质。发现如果一个点双中只要存在一个奇环,那么任何一个点都会在至少一个奇环之中,这一点可以通过画图说明,也就是不管这些环是交错的还是嵌套的,通过奇偶性推算都可以说明这一点。。

于是只要看每个点双有没有奇环即可。提到奇环,联想到二分图,所以只要二分图染色一下看合不合法即可。

不过本人在这个染色的地方卡了一下。。因为想到菊花图的数据(就是每次都在根处把所有边都查一遍)会不会被卡掉。。不过后来发现自己傻*了。。我在意的地方是在割点处会有遍历到属于其他点双的边,不过,由于割点最多$n$个,边由于最多连向$n$个点,所以$O(n^2)$复杂度,$n=1000$可以的。。但是这个染色的复杂度真心感觉好难受啊。。

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
#define mst(x) memset(x,0,sizeof x)
#define dbg(x) cerr << #x << " = " << x <<endl
#define dbg2(x,y) cerr<< #x <<" = "<< x <<" "<< #y <<" = "<< y <<endl
using namespace std;
typedef long long ll;
typedef double db;
typedef pair<int,int> pii;
template<typename T>inline T _min(T A,T B){return A<B?A:B;}
template<typename T>inline T _max(T A,T B){return A>B?A:B;}
template<typename T>inline char MIN(T&A,T B){return A>B?(A=B,):;}
template<typename T>inline char MAX(T&A,T B){return A<B?(A=B,):;}
template<typename T>inline void _swap(T&A,T&B){A^=B^=A^=B;}
template<typename T>inline T read(T&x){
x=;int f=;char c;while(!isdigit(c=getchar()))if(c=='-')f=;
while(isdigit(c))x=x*+(c&),c=getchar();return f?x=-x:x;
}
const int N=+,M=1e6+;
struct thxorz{
int head[N],to[M<<],nxt[M<<],tot;
inline void add(int x,int y){
to[++tot]=y,nxt[tot]=head[x],head[x]=tot;
to[++tot]=x,nxt[tot]=head[y],head[y]=tot;
}
inline void clear(){mst(head),tot=;}
}G;
int hate[N][N];
int n,m,ans;
#define y G.to[j]
vector<int> dcc[N];
int dc,dfn[N],low[N],tim,stk[N],Top,rt;
void tarjan(int x){
dfn[x]=low[x]=++tim;
if(rt==x&&!G.head[x]){++dc;dcc[dc].push_back(x);return;}
for(register int j=G.head[x];j;j=G.nxt[j])
if(!dfn[y]){
stk[++Top]=y,tarjan(y),MIN(low[x],low[y]);
if(low[y]==dfn[x]){
int tmp;++dc;
do tmp=stk[Top--],dcc[dc].push_back(tmp);while(tmp^y);
dcc[dc].push_back(x);
}
}
else MIN(low[x],dfn[y]);
}
int cl[N],tag[N],ban[N],flag,kai;
void dfs(int x,int clr){//dbg2(x,clr);
cl[x]=clr;
for(register int j=G.head[x];j&&!flag;j=G.nxt[j])if(ban[y]==kai){
if(!cl[y])dfs(y,-clr);
else if(cl[y]==clr){flag=;return;}
}
}
#undef y
inline void Clear(){G.clear();mst(hate),mst(tag),mst(dfn),mst(ban),mst(cl);dc=tim=ans=;}
int main(){//freopen("test.in","r",stdin);freopen("test.ans","w",stdout);
while(read(n),read(m),n||m){
Clear();
for(register int i=,x,y;i<=m;++i)read(x),read(y),hate[x][y]=hate[y][x]=;
for(register int i=;i<=n;++i)for(register int j=i+;j<=n;++j)if(!hate[i][j])G.add(i,j);
for(register int i=;i<=n;++i)if(!dfn[i])rt=i,Top=,tarjan(i);
for(register int i=;i<=dc;++i){
// if(dcc[i].size()<3)continue;<----will skip the line75--clear
for(register int j=;j<dcc[i].size();++j)cl[dcc[i][j]]=,ban[dcc[i][j]]=i;
flag=,kai=i,dfs(dcc[i][],);
if(flag)for(register int j=;j<dcc[i].size();++j)tag[dcc[i][j]]=;
dcc[i].clear();
}
for(register int i=;i<=n;++i)if(!tag[i])++ans;
printf("%d\n",ans);
}
return ;
}

poj2942 Knights of the Round Table[点双+二分图染色]的更多相关文章

  1. [POJ2942]Knights of the Round Table(点双+二分图判定——染色法)

    建补图,是两个不仇恨的骑士连边,如果有环,则可以凑成一桌和谐的打麻将 不能直接缩点,因为直接缩点求的是连通分量,点双缩点只是把环缩起来 普通缩点                             ...

  2. POJ2942 Knights of the Round Table[点双连通分量|二分图染色|补图]

    Knights of the Round Table Time Limit: 7000MS   Memory Limit: 65536K Total Submissions: 12439   Acce ...

  3. POJ2942 Knights of the Round Table 点双连通分量,逆图,奇圈

    题目链接: poj2942 题意: 有n个人,能够开多场圆桌会议 这n个人中,有m对人有仇视的关系,相互仇视的两人坐在相邻的位置 且每场圆桌会议的人数仅仅能为奇书 问有多少人不能參加 解题思路: 首先 ...

  4. POJ2942 Knights of the Round Table 点双连通分量 二分图判定

    题目大意 有N个骑士,给出某些骑士之间的仇恨关系,每次开会时会选一些骑士开,骑士们会围坐在一个圆桌旁.一次会议能够顺利举行,要满足两个条件:1.任意相互憎恨的两个骑士不能相邻.2.开会人数为大于2的奇 ...

  5. [POJ2942]:Knights of the Round Table(塔尖+二分图染色法)

    题目传送门 题目描述 亚瑟王要在圆桌上召开骑士会议,为了不引发骑士之间的冲突,并且能够让会议的议题有令人满意的结果,每次开会前都必须对出席会议的骑士有如下要求: .相互憎恨的两个骑士不能坐在直接相邻的 ...

  6. 【POJ 2942】Knights of the Round Table(双联通分量+染色判奇环)

    [POJ 2942]Knights of the Round Table(双联通分量+染色判奇环) Time Limit: 7000MS   Memory Limit: 65536K Total Su ...

  7. 【POJ】2942 Knights of the Round Table(双连通分量)

    http://poj.org/problem?id=2942 各种逗.... 翻译白书上有:看了白书和网上的标程,学习了..orz. 双连通分量就是先找出割点,然后用个栈在找出割点前维护子树,最后如果 ...

  8. 「题解」:[POJ2942]Knights of the Round Table

    问题 E: Knights of the Round Table 时间限制: 1 Sec  内存限制: 256 MB 题面 题目描述 作为一名骑士是一个非常有吸引力的职业:寻找圣杯,拯救遇难的少女,与 ...

  9. POJ2942 Knights of the Round Table【Tarjan点双联通分量】【二分图染色】【补图】

    LINK 题目大意 有一群人,其中有一些人之间有矛盾,现在要求选出一些人形成一个环,这个环要满足如下条件: 1.人数大于1 2.总人数是奇数 3.有矛盾的人不能相邻 问有多少人不能和任何人形成任何的环 ...

随机推荐

  1. poj1753 (高斯消元法求异或方程组)

    题目链接:http://poj.org/problem?id=1753 题意:经典开关问题,和poj1222一样,进行两次高斯消元即可,只用初始化的时候改一下初始状态.可能存在无解或多解的情况,多解要 ...

  2. 快速Get-JAVA-IO流

    第四阶段 IO IO流 前言: 前面的学习我们只能够在已有的一定封闭范围内进行一些操作,但是这显然是无趣的,也是不支持我们实现一些复杂的需求,所以Java提供IO流这样一种概念,方便我们对数据进行操作 ...

  3. [转帖]Google Chrome 解决 “您的连接不是私密连接”

    Google Chrome 解决 “您的连接不是私密连接” 和被毒霸劫持 自己搭建了 k8s的 dashboard 结果 chrome 最新版本的打不开了.. 百度了下 园友的解决方案很完美 这里面转 ...

  4. 在Eclipse中手动为其添加spring组件开发支持

    https://blog.csdn.net/Tajyl/article/details/79410897 注意找对应spring版本 进入eclipse >>help>>abo ...

  5. VS code 的使用

    VS code 是一个非常不错的代码编辑器.它不依赖与任何编译器或者解释器,但却能高效的利用第三方编译器或解释器来给用户提供良好的代码编写环境. 我喜欢VS code的三点,丰富强大的插件,快捷的语法 ...

  6. 异常处理 try

    语法错误 这种错误的不能使用异常处理,你自己粗心写错怪谁,哼哼哼 比如说少冒号啦,丢了括号啦 逻辑错误 try: num = int(input("请输入数字")) print(1 ...

  7. linux的定时器(timer_create,timer_gettime,timer_delete,SIGEV_SIGNAL)

    ref : http://blog.chinaunix.net/uid-28458801-id-5035347.html   系统中的一个模块需要频繁的获取系统时间,使用linux中内置的函数开销过大 ...

  8. varnish应用

    Nginx+Varnish+基本业务 ngnix nginx.conf配置文件 user root; worker_processes ; error_log logs/error.log crit; ...

  9. Fiddler 抓包工具详解

    Fiddler是一个蛮好用的抓包工具,可以将网络传输发送与接受的数据包进行截获.重发.编辑.转存等操作.也可以用来检测网络安全.反正好处多多,举之不尽呀!当年学习的时候也蛮费劲,一些蛮实用隐藏的小功能 ...

  10. 空间变换网络(STN)原理+2D图像空间变换+齐次坐标系讲解

    空间变换网络(STN)原理+2D图像空间变换+齐次坐标系讲解 2018年11月14日 17:05:41 Rosemary_tu 阅读数 1295更多 分类专栏: 计算机视觉   版权声明:本文为博主原 ...