BZOJ 2199: [Usaco2011 Jan]奶牛议会
2199: [Usaco2011 Jan]奶牛议会
Time Limit: 10 Sec Memory Limit: 259 MB
Submit: 375 Solved: 241
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 Y 2 N
1 N 2 N
1 Y 3 Y
1 Y 2 Y
Sample Output
HINT
Source
分析:
2-SAT问题...
考虑对于$xy$两个议案,如果$x$对应$Y$,$y$对应$N$,那么就代表这两个点至少选一个,也就是说$x$的$N$和$y$的$Y$不能同时选择,那么就代表存在两条边$<x(N),y(N)>,<y(Y),x(Y)>$...然后如果$dfs$发现存在一个议案选$Y$必须选$N$,选$N$必须选$Y$,那么就不存在合法方案,否则如果存在选$Y$必须$N$,那么就只选$N$就好了...
代码:
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
//by NeighThorn
using namespace std; const int maxn=2000+5,maxm=8000+5; int n,m,cnt,hd[maxn],to[maxm],nxt[maxm],vis[maxn],cho[maxn],can[maxn]; char s[2][3]; inline int check(char a){
return a=='Y';
} inline void add(int x,int y){
to[cnt]=y;nxt[cnt]=hd[x];hd[x]=cnt++;
} inline bool dfs(int x){
if(cho[x^1]) return false;
vis[x]=cho[x]=1;
for(int i=hd[x];i!=-1;i=nxt[i])
if(!vis[to[i]])
if(!dfs(to[i]))
return false;
return true;
} signed main(void){
scanf("%d%d",&n,&m);
memset(hd,-1,sizeof(hd));
for(int i=1,x,y,x1,y1,x2,y2;i<=m;i++){
scanf("%d%s%d%s",&x,s[0],&y,s[1]);
x1=x<<1|check(s[0][0]),y1=y<<1|(check(s[1][0])^1);
y2=y<<1|check(s[1][0]),x2=x<<1|(check(s[0][0])^1);
add(x1,y1);add(y2,x2);
}
for(int i=1;i<=n;i++){
memset(cho,0,sizeof(cho));
memset(vis,0,sizeof(vis));
can[i<<1 ]=dfs(i<<1 );
memset(cho,0,sizeof(cho));
memset(vis,0,sizeof(vis));
can[i<<1|1]=dfs(i<<1|1);
}
for(int i=1;i<=n;i++)
if(!can[i<<1]&&!can[i<<1|1])
return puts("IMPOSSIBLE"),0;
for(int i=1;i<=n;i++){
if(!can[i<<1]) cho[i<<1]=-1,cho[i<<1|1]=1;
else if(!can[i<<1|1]) cho[i<<1|1]=-1,cho[i<<1]=1;
else cho[i<<1]=1,cho[i<<1|1]=1;
}
for(int i=1;i<=n;i++){
if(cho[i<<1]==-1) printf("N");
else if(cho[i<<1|1]==-1) printf("Y");
else printf("?");
}
return 0;
}
By NeighThorn
BZOJ 2199: [Usaco2011 Jan]奶牛议会的更多相关文章
- bzoj 1823: [JSOI2010]满汉全席 && bzoj 2199 : [Usaco2011 Jan]奶牛议会 2-sat
noip之前学的内容了,看到题竟然忘了怎么建图了,复习一下. 2-sat 大概是对于每个元素,它有0和1两种选择,必须选一个但不能同时选.这之间又有一些二元关系,比如x&y=1等等... 先把 ...
- BZOJ 2199: [Usaco2011 Jan]奶牛议会 [2-SAT 判断解]
http://www.lydsy.com/JudgeOnline/problem.php?id=2199 题意:裸的2-SAT,但是问每个变量在所有解中是只能为真还是只能为假还是既可以为真又可以为假 ...
- BZOJ.2199.[USACO2011 Jan]奶牛议会(2-SAT)
题目链接 建边不说了.对于议案'?'的输出用拓扑不好判断,直接对每个议案的结果DFS,看是否会出现矛盾 Tarjan也用不到 //964kb 76ms #include <cstdio> ...
- bzoj 2199: [Usaco2011 Jan]奶牛议会【2-SAT】
好久没写2-SAT了啊,还以为是网络流 设点x为选,x'为不选,因为一头牛至少要满足一个条件,所以对于牛条件的两个点,选了一个不符合的点,就要选另一个符合的点,这样连两条边 然后枚举所有议案的选和不选 ...
- 2199: [Usaco2011 Jan]奶牛议会 2-sat
链接 https://www.luogu.org/problemnew/show/P3007 https://www.lydsy.com/JudgeOnline/problem.php?id=2199 ...
- 【BZOJ2199】[Usaco2011 Jan]奶牛议会 2-SAT
[BZOJ2199][Usaco2011 Jan]奶牛议会 Description 由于对Farmer John的领导感到极其不悦,奶牛们退出了农场,组建了奶牛议会.议会以“每头牛 都可以获得自己想要 ...
- 【BZOJ2199】 [Usaco2011 Jan]奶牛议会
Description 由于对Farmer John的领导感到极其不悦,奶牛们退出了农场,组建了奶牛议会.议会以“每头牛 都可以获得自己想要的”为原则,建立了下面的投票系统: M只到场的奶牛 (1 & ...
- BZOJ2199: [Usaco2011 Jan]奶牛议会(2-SAT)
Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 559 Solved: 360[Submit][Status][Discuss] Descriptio ...
- BZOJ2199[Usaco2011 Jan]奶牛议会——2-SAT+tarjan缩点
题目描述 由于对Farmer John的领导感到极其不悦,奶牛们退出了农场,组建了奶牛议会.议会以“每头牛 都可以获得自己想要的”为原则,建立了下面的投票系统: M只到场的奶牛 (1 <= M ...
随机推荐
- ln -s 软链接产生Too many levels of symbolic links错误
不能使用相对路径, ln -s ./cmake /usr/bin/ 而是要 ln -s /usr/local/bin/cmake /usr/bin/
- C++基础 const
1. C中的const C中const变量只是只读变量,有自己存储空间.可能被存放在 栈.堆.数据段,所以可以修改. 2. C++中const 可能分配空间,也可能不分配空间. 当 const 为全局 ...
- lambda & 三元运算
lambda & 三元运算 lambda: 1 >>> def add(x,y): #定义一个加法函数 2 return x+y ...
- phpstorm调试配置 Xdebug
这已经楼主第二次因为phpstorm的调试配置折腾了几个小时,这次一定要记下来!!! 以Xdebug chrome浏览器为例 一:安装 JetBrains IDE Support 二:安装 Xdebu ...
- webstrom Certificate validation failed
今天好烦.因为装了一个webstrome,我的svn不管用了. 为了防止webstrom,我的日期改了,日期改了,csdn登不上去了.告诉我时期不对. 草草哦哦. 这就是那个svn出问题之后的画面. ...
- Toolbar中menu菜单文字颜色的修改
Toolbar菜单中menu当中我们大多数都使用图片来按钮,可是有些时候我们也会直接使用文字,文字的颜色如何修改呢. 其实很简单,我们只要修改styles.xml文件中,添加一句 <item n ...
- nodejs基础1
nodejs学习网站: https://github.com/alsotang/node-lessons 1.全局对象 (1)node中没有window对象,有global对象替代window对象 g ...
- IOS多网卡抓包
linux下libpcap支持从多网卡抓包,设置为any即可 在IOS或者mac上就无法通过次方法抓取所有网卡报文 1.通过设置libevent事件回调,每个网卡注册读事件, fd通过 pd = pc ...
- CSS3 3D圆形设计教程
http://www.htmleaf.com/ziliaoku/qianduanjiaocheng/201502061338.html
- 关于p标签的嵌套问题
今天群里问了一个p的问题,初看我觉得恩这么简单我应该知道. 他代码如下: <!DOCTYPE HTML> <html> <head> <meta charse ...