hdu 1824 2-sat问题(判断)
来源:互联网 发布:java iterator用法 编辑:程序博客网 时间:2024/05/24 06:00
/*题意:u,v,w队长,队员,队长留下两个队员可以回家,两个队员留下,队长回家2-sat问题,把两个队员看成一个整体就变成一个简单2-sat问题了*/#include<stdio.h>#include<string.h>#include<algorithm>#include<stdlib.h>using namespace std;#define N 6100#define NN 5100struct node {int u,v,w,next;}bian[NN*8];int head[N],yong,low[N],dfn[N],belong[N],ans,top,index,stac[N],vis[N];void init(){ memset(head,-1,sizeof(head)); yong=index=ans=top=0; memset(vis,0,sizeof(vis)); memset(dfn,0,sizeof(dfn));}void addedge(int u,int v){ bian[yong].v=v; bian[yong].next=head[u]; head[u]=yong++;}void tarjan(int u){ low[u]=dfn[u]=++index; stac[++top]=u; vis[u]=1; int i; for(i=head[u]; i!=-1; i=bian[i].next) { int v=bian[i].v; if(!dfn[v]) { tarjan(v); low[u]=min(low[u],low[v]); } else if(vis[v]) low[u]=min(low[u],dfn[v]); } if(low[u]==dfn[u]) { ans++; int t; do { t=stac[top--]; belong[t]=ans; vis[t]=0; } while(t!=u); }}int slove(int n){ int i; for(i=0; i<=n; i++) if(!dfn[i]) tarjan(i); // printf("%d\n",ans); for(i=0; i<=n; i+=2) if(belong[i]==belong[i+1]) return 0; return 1;}int indx[N];int main() { int n,m,i,u,len,v,w; while(scanf("%d%d",&n,&m)!=EOF) { init(); len=-1; for(i=0;i<n;i++) { scanf("%d%d%d",&u,&v,&w); indx[u]=++len; indx[v]=++len; indx[w]=len; } for(i=0;i<m;i++) { scanf("%d%d",&u,&v); addedge(indx[u],indx[v]^1); addedge(indx[v],indx[u]^1); } if(!slove(len)) printf("no\n"); else printf("yes\n"); }return 0;}
0 0
- hdu 1824 2-sat问题(判断)
- HDU 1824 Let's go home (2-SAT判断)
- HDU 4115 Eliminate the Conflict (2-SAT判断)
- hdu 1824 (2-SAT)
- hdu 1824 2-sat
- hdu 3622(二分+2-sat判断可行性)
- hdu 4115 石头剪子布(2-sat问题)
- HDU 1824 2-sat算法
- hdu 3062 (2-sat)
- HDU 3622 Bomb Game【2-SAT 问题】
- hdu 3622 2-sat经典问题
- HDU 3622 Bomb Game【2-SAT 问题】
- Party+hdu+简单2sat问题
- 图论2-sat问题 HDU 3062
- HDU 1824 Let's go home 2-sat判断可行解
- hdu 1824 && hdU 3062 2-SAT经典
- HDU 4421Bit Magic 2-sat判断可行解
- HDU 1824 Let's go home(2-sat)
- Ural 1309 Dispute (递推)
- 理解操作系统4--文件管理疑惑总结
- CSS3-基本选择器语法(实战)
- ACM培训练习总结 2
- 英语学习 3 python
- hdu 1824 2-sat问题(判断)
- CGLib动态代理原理及实现
- nyoj106背包问题(贪心)
- C语言的那些秘密之---函数返回局部变量
- Quartz 2D的简单使用
- Linux下php+mysql+nginx编译搭建(一)
- 2014青岛理工大学ACM邀请赛总结
- Servet Filter Listener 详解
- 2014-11-8Android学习-------AnimationListener方法-------动画Animation学习篇