题意:两个人石头剪刀布,一个人的出法已确定,另一个人的出法有一定约束,某两次要相同或者不同,问你第二个人能否全部都不失败。

思路:根据Bob出的情况,我们可以确定每次Alice有两种方案。

R与P,S矛盾,P与R,S矛盾,S与R,P矛盾。

根据Bob出的情况建边:

如果Bob出的是石头(R)则Alice可以出石头或者布,就是~R与~P矛盾,~P与~R矛盾,建边~R—>P,~P—>R。

........................................

根据约束条件:

如果a,b两轮是一样的就是Ra与~Rb矛盾,Rb与~Ra矛盾,建边Ra—>Rb,Rb—>Ra,

........................................

如果a,b两轮不一样就是Ra与Rb矛盾,Rb与Ra矛盾,建边Ra—>~Rb,Rb—>~Ra,

.......................................

#include<stdio.h>
#include<string.h>
#include<stack>
const int N=61000;
using namespace std;
int head[N],num,low[N],dfs[N],idx,ans,belong[N],ins[N];
stack<int>Q;
struct edge
{
int st,ed,next;
}e[N*10];
void addedge(int x,int y)
{
e[num].st=x;e[num].ed=y;e[num].next=head[x];head[x]=num++;
}
void Tarjan(int u)//缩点
{
int i,v;
Q.push(u);
ins[u]=1;
low[u]=dfs[u]=idx++;
for(i=head[u];i!=-1;i=e[i].next)
{
v=e[i].ed;
if(dfs[v]==-1)
{
Tarjan(v);
low[u]=low[u]>low[v]?low[v]:low[u];
}
else if(ins[v]==1)
low[u]=low[u]>dfs[v]?dfs[v]:low[u];
}
if(dfs[u]==low[u])
{
do
{
v=Q.top();
Q.pop();
ins[v]=0;//又忘了这个,调了半天
belong[v]=ans;
}while(v!=u);
ans++;
}
}
int main()
{
int i,x,y,a[3],b[3],c,t,op=1,k,n,m;
scanf("%d",&t);
while(t--)
{
memset(head,-1,sizeof(head));
num=0;
scanf("%d%d",&n,&m);
k=3*n;
for(i=1;i<=n;i++)
{
a[0]=i;a[1]=a[0]+n;a[2]=a[1]+n;
addedge(a[0],k+a[1]);addedge(a[0],k+a[2]);//R->非P,R->非S
addedge(a[1],k+a[0]);addedge(a[1],k+a[2]);//P->非R,P->非S
addedge(a[2],k+a[0]);addedge(a[2],k+a[1]);//S->非R,s->非R
}
for(i=1;i<=n;i++)
{
a[0]=i;a[1]=a[0]+n;a[2]=a[1]+n;
scanf("%d",&x);
if(x==3)//Bob出的是剪刀
{
addedge(k+a[0],a[2]);//非R->P
addedge(k+a[2],a[0]);//非P->R
}
else
{
addedge(k+a[x],a[x-1]);
addedge(k+a[x-1],a[x]);
}
}
for(i=0;i<m;i++)
{
scanf("%d%d%d",&x,&y,&c);
a[0]=x;a[1]=a[0]+n;a[2]=a[1]+n;
b[0]=y;b[1]=b[0]+n;b[2]=b[1]+n;
if(c==0)
{
addedge(a[0],b[0]);addedge(b[0],a[0]);
addedge(a[1],b[1]);addedge(b[1],a[1]);
addedge(a[2],b[2]);addedge(b[2],a[2]); }
else
{
addedge(a[0],k+b[0]);addedge(b[0],k+a[0]);
addedge(a[1],k+b[1]);addedge(b[1],k+a[1]);
addedge(a[2],k+b[2]);addedge(b[2],k+a[2]);
}
}
memset(dfs,-1,sizeof(dfs));
idx=0,ans=0;
memset(belong,0,sizeof(belong));
memset(ins,0,sizeof(ins));
for(i=1;i<=k+k;i++)
{
if(dfs[i]==-1)
Tarjan(i);
}
for(i=1;i<=n;i++)
{
a[0]=i;a[1]=a[0]+n;a[2]=a[1]+n;
if(belong[a[0]]==belong[a[0]+k])break;
if(belong[a[1]]==belong[a[1]+k])break;
if(belong[a[2]]==belong[a[2]+k])break;
}
printf("Case #%d: ",op++);
if(i<=n)
printf("no\n");
else printf("yes\n");
}
return 0;
}

hdu 4115 (2—SAT)的更多相关文章

  1. HDU 4115 Eliminate the Conflict(2-sat)

    HDU 4115 Eliminate the Conflict pid=4115">题目链接 题意:Alice和Bob这对狗男女在玩剪刀石头布.已知Bob每轮要出什么,然后Bob给Al ...

  2. hdu 4115 Eliminate the Conflict ( 2-sat )

    Eliminate the Conflict Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/O ...

  3. hdu 4115 2-SAT判定

    思路:将每个回合的平手和赢最为一对对立状态.那么后面就是2-SAT判断了. #include<iostream> #include<cstdio> #include<al ...

  4. hdu 4115 石头剪子布(2-sat问题)

    /* 意甲冠军:石头剪子布,目前已知n周围bob会有什么,对alice限制.供u,v,w:设w=0说明a,b回合必须出的一样 否则,必须不一样.alice假设输一回合就输了,否则就赢了 解: 2-sa ...

  5. HDU 4115 Eliminate the Conflict

    2-SAT,拆成六个点. #include<cstdio> #include<cstring> #include<cmath> #include<stack& ...

  6. Eliminate the Conflict HDU - 4115(2-sat 建图 hhh)

    题意: 石头剪刀布 分别为1.2.3,有n轮,给出了小A这n轮出什么,然后m行,每行三个数a b k,如果k为0 表示小B必须在第a轮和第b轮的策略一样,如果k为1 表示小B在第a轮和第b轮的策略不一 ...

  7. HDU 4115 Eliminate the Conflict(2-SAT)(2011 Asia ChengDu Regional Contest)

    Problem Description Conflicts are everywhere in the world, from the young to the elderly, from famil ...

  8. [GodLove]Wine93 Tarining Round #4

    比赛链接: http://acm.hust.edu.cn/vjudge/contest/view.action?cid=44903#overview 题目来源: 2011 Asia ChengDu R ...

  9. 【图论】2-sat总结

    2-sat总结 2-sat问题,一般表现的形式为.每一个点有两种方式a,b,要么选a,要么选b.而且点点之间有一些约束关系.比如:u和v至少一个选a.那么这就是一个表达式.把a当成真,b当成假,那就是 ...

随机推荐

  1. javaweb学习总结(四十七)——监听器(Listener)在开发中的应用

    监听器在JavaWeb开发中用得比较多,下面说一下监听器(Listener)在开发中的常见应用 一.统计当前在线人数 在JavaWeb应用开发中,有时候我们需要统计当前在线的用户数,此时就可以使用监听 ...

  2. ios loading视图动画(模仿58同城)

    最近看了58同城的加载视图,感觉很不错,如下图: 所以想模仿写一个,下载58同城的app,解压,发现它用的是图片来实现的动画效果, 并不是绘制出来的,所以这就相对简单些了,其实整个动画的逻辑不复杂,无 ...

  3. Protected Functions 是理解OO的难点和关键

    Protected Functions 是理解OO的难点和关键 private和public函数都好理解,这里就不多说了,夹在中间的prortected却有许多精妙之处,说说我的几个疑问和看法:1. ...

  4. vmware tools安装程序无法继续,Microsoft Runtime DLL安装程序未能完成安装。的解决方法

    vmware tools安装程序无法继续,Microsoft Runtime DLL安装程序未能完成安装.的解决方法_华英雄_新浪博客 http://blog.sina.com.cn/s/blog_5 ...

  5. WPF之小动画一

    定义动画: 直接使用Element进行BeginAnimation DoubleAnimation animation = new DoubleAnimation(); animation.By = ...

  6. P137、面试题23:从上往下打印二叉树

    题目:从上往下打印出二叉树的每个结点,同一层的结点按照从左到右的顺序打印.例如输入如图的二叉树,则依次打印出8,6,10,5,7,9,11.(其实是按层遍历)二叉树结点的定义如下:struct Bin ...

  7. matlab 设置横纵坐标刻度的字体!!

    set(gca,'FontSize',16) %%设置横纵坐标字体的大小

  8. 【剑指offer】找出数组中出现一次的两个数

    2013-09-08 10:50:46 一个整型数组中,除了两个数字之外,其他数字都出现了2次,找出这两个只出现一次的数字,要求时间复杂度是O(N),空间复杂度是O(1). 小结: 任何数与0异或,结 ...

  9. 【HDOJ】3948 The Number of Palindromes

    后缀数组求不重复回文子串数目.注意dp数组. /* 3948 */ #include <iostream> #include <sstream> #include <st ...

  10. mac terminal终端ls命令参数详解

    原文:https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man1/ls.1.html -a ...