BZOJ2199[Usaco2011 Jan]奶牛议会——2-SAT+tarjan缩点
题目描述
输入
输出
样例输入
1 Y 2 N
1 N 2 N
1 Y 3 Y
1 Y 2 Y
样例输出
#include<set>
#include<map>
#include<stack>
#include<cmath>
#include<queue>
#include<vector>
#include<bitset>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,m;
int a,b;
char s[2];
char t[2];
int ans[2010];
int to[8010];
int head[2010];
int next[8010];
int vis[2010];
int tot;
void add(int x,int y)
{
tot++;
next[tot]=head[x];
head[x]=tot;
to[tot]=y;
}
void dfs(int x)
{
if(vis[x])
{
return ;
}
vis[x]=1;
for(int i=head[x];i;i=next[i])
{
dfs(to[i]);
}
}
bool check(int x)
{
memset(vis,0,sizeof(vis));
dfs(x);
for(int i=0;i<n;i++)
{
if(vis[i<<1]&&vis[i<<1|1])
{
return 0;
}
}
return 1;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++)
{
scanf("%d%s%d%s",&a,s,&b,t);
a=(a-1)<<1;
if(s[0]=='N')
{
a|=1;
}
b=(b-1)<<1;
if(t[0]=='N')
{
b|=1;
}
add(a^1,b);
add(b^1,a);
}
for(int i=0;i<n;i++)
{
ans[i<<1]=check(i<<1);
ans[i<<1|1]=check(i<<1|1);
if(!ans[i<<1]&&!ans[i<<1|1])
{
printf("IMPOSSIBLE\n");
return 0;
}
}
for(int i=0;i<n;i++)
{
if(ans[i<<1]&&ans[i<<1|1])
{
printf("?");
}
else if(ans[i<<1])
{
printf("Y");
}
else
{
printf("N");
}
}
}
tarjan缩点的代码。
#include<set>
#include<map>
#include<stack>
#include<cmath>
#include<queue>
#include<vector>
#include<bitset>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,m;
int a,b;
char ch1[2];
char ch2[2];
int ans[2010];
int to[8010];
int head[2010];
int next[8010];
int vis[2010];
int tot;
int dep[2010];
int low[2010];
int s[2010];
int v[2010];
int t[2010];
int top;
int num;
int now;
int sum;
vector<int>q[2010];
void add(int x,int y)
{
tot++;
next[tot]=head[x];
head[x]=tot;
to[tot]=y;
}
void tarjan(int x)
{
t[++top]=x;
v[x]=1;
dep[x]=low[x]=++num;
for(int i=head[x];i;i=next[i])
{
if(!dep[to[i]])
{
tarjan(to[i]);
low[x]=min(low[x],low[to[i]]);
}
else if(v[to[i]])
{
low[x]=min(low[x],dep[to[i]]);
}
}
if(dep[x]==low[x])
{
sum++;
do
{
now=t[top];
top--;
s[now]=sum;
v[now]=0;
}
while(now!=x);
}
}
void dfs(int x)
{
if(vis[x])
{
return ;
}
vis[x]=1;
int len=q[x].size();
for(int i=0;i<len;i++)
{
dfs(q[x][i]);
}
}
bool check(int x)
{
memset(vis,0,sizeof(vis));
dfs(s[x]);
for(int i=0;i<n;i++)
{
if(vis[s[i<<1]]&&vis[s[i<<1|1]])
{
return 0;
}
}
return 1;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++)
{
scanf("%d%s%d%s",&a,ch1,&b,ch2);
a=(a-1)<<1;
if(ch1[0]=='N')
{
a|=1;
}
b=(b-1)<<1;
if(ch2[0]=='N')
{
b|=1;
}
add(a^1,b);
add(b^1,a);
}
for(int i=0;i<=2*n-2;i++)
{
if(!dep[i])
{
tarjan(i);
}
}
for(int i=0;i<n;i++)
{
if(s[i<<1]==s[i<<1|1])
{
printf("IMPOSSIBLE\n");
return 0;
}
}
for(int i=0;i<=2*n-2;i++)
{
for(int j=head[i];j;j=next[j])
{
if(s[i]!=s[to[j]])
{
q[s[i]].push_back(s[to[j]]);
}
}
}
for(int i=0;i<n;i++)
{
ans[i<<1]=check(i<<1);
ans[i<<1|1]=check(i<<1|1);
if(!ans[i<<1]&&!ans[i<<1|1])
{
printf("IMPOSSIBLE\n");
return 0;
}
}
for(int i=0;i<n;i++)
{
if(ans[i<<1]&&ans[i<<1|1])
{
printf("?");
}
else if(ans[i<<1])
{
printf("Y");
}
else
{
printf("N");
}
}
}
BZOJ2199[Usaco2011 Jan]奶牛议会——2-SAT+tarjan缩点的更多相关文章
- 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. 以前的2-SAT都是用并查集写的,只能应用于极小的一部分情况,这次学了一正式的2-SAT,是用一张有向图来表示其依赖关系. 2-SAT的介绍参见刘汝佳<训练指南&g ...
- 【BZOJ2199】[Usaco2011 Jan]奶牛议会 2-SAT
[BZOJ2199][Usaco2011 Jan]奶牛议会 Description 由于对Farmer John的领导感到极其不悦,奶牛们退出了农场,组建了奶牛议会.议会以“每头牛 都可以获得自己想要 ...
- BZOJ 2199: [Usaco2011 Jan]奶牛议会
2199: [Usaco2011 Jan]奶牛议会 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 375 Solved: 241[Submit][S ...
- 【BZOJ2199】 [Usaco2011 Jan]奶牛议会
Description 由于对Farmer John的领导感到极其不悦,奶牛们退出了农场,组建了奶牛议会.议会以“每头牛 都可以获得自己想要的”为原则,建立了下面的投票系统: M只到场的奶牛 (1 & ...
- BZOJ.2199.[USACO2011 Jan]奶牛议会(2-SAT)
题目链接 建边不说了.对于议案'?'的输出用拓扑不好判断,直接对每个议案的结果DFS,看是否会出现矛盾 Tarjan也用不到 //964kb 76ms #include <cstdio> ...
- 2199: [Usaco2011 Jan]奶牛议会 2-sat
链接 https://www.luogu.org/problemnew/show/P3007 https://www.lydsy.com/JudgeOnline/problem.php?id=2199 ...
- BZOJ 2199: [Usaco2011 Jan]奶牛议会 [2-SAT 判断解]
http://www.lydsy.com/JudgeOnline/problem.php?id=2199 题意:裸的2-SAT,但是问每个变量在所有解中是只能为真还是只能为假还是既可以为真又可以为假 ...
- bzoj 1823: [JSOI2010]满汉全席 && bzoj 2199 : [Usaco2011 Jan]奶牛议会 2-sat
noip之前学的内容了,看到题竟然忘了怎么建图了,复习一下. 2-sat 大概是对于每个元素,它有0和1两种选择,必须选一个但不能同时选.这之间又有一些二元关系,比如x&y=1等等... 先把 ...
随机推荐
- jmeter(十三)常见问题及解决方法
jmeter作为一个开源的纯Java性能测试工具,工作中极大的方便了我们进行接口.性能测试,但使用过程中也遇到了很多的问题,下面就记录一下自己遇到的问题,后续会不断更新... 1.获取日志 在使用jm ...
- C#连接数据库插入数据
首先是安装JDBC操作数据库的包,,当然自己看着办哈,可以自己下载以后导入,或者直接让软件本身下载 第一种方式 第二种 咱自己下载个低版本的 点击这个链接 点击以后呢可以直接下载下来,然后导入(大家百 ...
- FFmpeg在JAVA中的使用以及Process.waitFor()引发的阻塞问题
此文已由作者叶海啸授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. FFmpeg是一个开源免费跨平台的视频和音频流方案,可以快速对音视频流进行多方面的处理,本文主要介绍FFmp ...
- 使用Webuploader大文件分片传输
背景:50G大文件的HTTP上传至服务器. 好了,根据这个命题,可以开始研究我们怎么做才能把这么大的文件上传成功. 分片上传是肯定的,断点续传也是要有的,进度可视化那就更好了,基于这些,我选择了Web ...
- 3.4《想成为黑客,不知道这些命令行可不行》(Learn Enough Command Line to Be Dangerous)——grepping(检索目标行命令)
grep是检查文件内容最强大的工具之一,这也许不能代表什么,但这不是重点.的确,grep常用作动词,比如'你完全应该检索(grep)那个文件'. grep最常用于在文件中搜索子字符串.例如,我们在第三 ...
- Luogu4139 上帝与集合的正确用法 拓展欧拉定理
传送门 题意:求$2^{2^{2^{2^{...}}}} \mod p$的值.$p \leq 10^7$ 最开始想到的是$x \equiv x^2 \mod p$,然后发现不会做... 我们可以想到拓 ...
- 转的一个Java基本功
京京肚肚撸代码 2017-04-11 00:21 很早之前, 记得一次面试, 面试官问存储金钱用什么数据类型? 当时只知道8种数据类型(boolean, byte, short, int, long, ...
- 从angularjs传递参数至Web API
昨天分享的博文<angularjs呼叫Web API>http://www.cnblogs.com/insus/p/7772022.html,只是从Entity获取数据,没有进行参数POS ...
- C# WPF DataGrid 分组(Group)
原文:C# WPF DataGrid 分组(Group) 效果如图,每个列的名字可以自定义.我随便用了”File”和”Attachment Name”. 在Window的Resources里面设置S ...
- NOIP常见模板集合
Preface 这篇博客记录的是我联赛前虽然只有两天了的打板子记录. 只求真的能给我起到些作用吧,一般按照难度排序. 而且从这篇博客开始我会用H3的标题代替H4 为了节约篇幅,以下的代码一般均以cla ...