可以把一对夫妇当成一个节点,然后拆点的话,h和w分别为真和假,然后直接按照题目中说的建图染色即可

#include <iostream>
#include <cstdio>
#include <cstring>
#include <vector>
#include <queue>
#include <algorithm>
using namespace std;
const int maxn = 100;
const int maxm = 1000;
struct node{
int v,next;
}edge[maxm];
int res[maxm][2],head[maxn],low[maxn],dfn[maxn],stack[maxn],in[maxn],fa[maxn],ha[maxn];
int color[maxn];
int n,m,Time,top,scc_cnt,id;
vector<int>DAG[maxn];
queue<int>que;
void add_edge(int u,int v){
edge[id].v = v;edge[id].next = head[u]; head[u] = id++;
}
void init(){
memset(head,-1,sizeof(head));
memset(in,0,sizeof(in));
memset(dfn,0,sizeof(dfn));
memset(fa,0,sizeof(fa));
id = 0;
int i; int u,v;
char ch1,ch2; for(i = 0; i < m; i++){
scanf("%d%c %d%c",&u,&ch1,&v,&ch2);
u <<= 1;v <<= 1;
if(ch1 == 'w')u ^= 1;
if(ch2 == 'w')v ^= 1;
//必须在一起的连边
add_edge(u^1,v);
add_edge(v^1,u);
}
//这条边必须要加
add_edge(0,1);
}
int min(int x,int y){
return x < y ? x : y;
}
void tarjan(int u){//求强连通分量并缩点
dfn[u] = low[u] = ++Time;
stack[top++] = u;in[u] = 1;
for(int id = head[u]; id != -1; id = edge[id].next){
int v = edge[id].v;
if(!dfn[v]){
tarjan(v);
low[u] = min(low[v],low[u]);
}
else if(in[v])low[u] = min(low[u],dfn[v]);
}
if( dfn[u] == low[u]){
scc_cnt++;
do{
int v = stack[--top];
fa[v] = scc_cnt;
in[v] = 0;
}while(u != stack[top]);
}
}
void topsort(){//拓扑排序并着色
memset(color,0,sizeof(color));
while(!que.empty()){
int u = que.front();
que.pop();
if(!color[u])color[u] = 1,color[ha[u]] = 2;
for(int i = 0; i < DAG[u].size(); i++){
int v = DAG[u][i];
in[v]--;
if(!in[v])que.push(v);
}
}
}
int main(){
// freopen("in.txt","r",stdin);
while(~scanf("%d%d",&n,&m),n||m){
init();
Time = top = scc_cnt = 0;
int i;
for( i = 0; i < 2*n; i++)
if(!dfn[i])tarjan(i);
for(i = 0; i < n; i ++)//夫妻不能做在同一边
if(fa[i*2] == fa[i*2+1])break;
else {
ha[fa[i*2]] = fa[i*2+1];ha[fa[i*2+1]] = fa[i*2];
}
if( i < n){
puts("bad luck");
continue;
}
memset(in,0,sizeof(in));
for( i = 1; i <= scc_cnt; i++)DAG[i].clear();
//建反序拓扑图
for(int u = 0; u < n*2; u++){
for( id = head[u] ; id != -1; id = edge[id].next){
int v = edge[id].v;
if( fa[u] != fa[v]){
DAG[fa[v]].push_back(fa[u]);in[fa[u]]++;
}
}
}
while(!que.empty())que.pop();
for( i = 1 ; i <= scc_cnt; i++)
if(!in[i])que.push(i);
topsort();
//输出
for(i = 2; i < 2*n; i += 2){ if(i!=2)printf(" ");
if(color[fa[i]] == color[fa[0]] )printf("%dw",i/2);
else printf("%dh",i/2);
}
puts("");
}
return 0;
}

  

UVA 11294 wedding 2-sat的更多相关文章

  1. UVA 11294 - Wedding(Two-Set)

    UVA 11294 - Wedding 题目链接 题意:有n对夫妻,0号是公主.如今有一些通奸关系(男男,女女也是可能的)然后要求人分配在两側.夫妻不能坐同一側.而且公主对面一側不能有两个同奸的人,问 ...

  2. UVA 11294 Wedding

    给n对夫妇安排座位,其中0h,0w分别表示新郎,新娘.同一对新郎,新娘不能坐在同一侧,而且互为通奸关系的人不能同时坐在新娘对面. 这道题目真是掉尽节操啊,,,欧美的氛围还是比较开放的. 分析: 首先说 ...

  3. UVA 11294 Wedding(2-sat)

    2-sat.不错的一道题,学到了不少. 需要注意这么几点: 1.题目中描述的是有n对夫妇,其中(n-1)对是来为余下的一对办婚礼的,所以新娘只有一位. 2.2-sat问题是根据必然性建边,比如说A与B ...

  4. UVa 11294 Wedding (TwoSat)

    题意:有 n-1 对夫妻参加一个婚宴,所有人都坐在一个长长的餐桌左侧或者右侧,新郎和新娘面做面坐在桌子的两侧.由于新娘的头饰很复杂,她无法看到和她坐在同一侧餐桌的人,只能看到对面餐桌的人.任意一对夫妻 ...

  5. Wedding UVA - 11294(2-SAT男女分点)

    题意: 有N-1对夫妻参加一个婚宴,所有人都坐在一个长长的餐桌左侧或者右侧,新郎和新娘面做面坐在桌子的两侧.由于新娘的头饰很复杂,她无法看到和她坐在同一侧餐桌的人,只能看到对面餐桌的人.任意一对夫妻不 ...

  6. uva 11294

    Problem E: Wedding Up to thirty couples will attend a wedding feast, at which they will be seated on ...

  7. UVa 11450 - Wedding shopping

    题目大意:我们的朋友Bob要结婚了,所以要为他买一些衣服.有m的资金预算,要买c种类型的衣服(衬衫.裤子等),而每种类型的衣服有k个选择(只能做出一个选择),每个选择的衣服都有一个价格,问如何选择才能 ...

  8. Uva 11294 婚姻

    题目链接:https://vjudge.net/contest/166461#problem/C 题意: n对夫妻,有m对人吵过架,不能排在同一边,求新娘的一边的人: 分析: 每对夫妻,看成两个点,女 ...

  9. ACM-ICPC Dhaka Regional 2012 题解

    B: Uva: 12582 - Wedding of Sultan 给定一个字符串(仅由大写字母构成)一个字母表示一个地点,经过这个点或离开这个点都输出这个地点的字母) 问: 每一个地点经过的次数(维 ...

随机推荐

  1. memCached的配置文件 配置

    <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...

  2. HTML第六章 盒子模型

    什么是盒子模型: (1)边框: (2)内边距: (3)外边距: (4)元素内容·: (5)背景色·: 边框: 属性: 颜色(border-color),粗细(border-width),样式(bord ...

  3. 堆排序(实现c++)

    堆可以看作是一个完全二叉树,分为大顶堆和小顶堆,本文我们以大顶堆为例来实现堆排序. (1)建堆 先把给定的序列转换成一棵完全二叉树,然后逐步对其调整使其每个结点的值都大于其两个子结点的值,因此我们需要 ...

  4. 【React踩坑记四】React项目中引入并使用js-xlsx上传插件(结合antdesign的上传组件)

    最近有一个前端上传并解析excel/csv表格数据的需求. 于是在github上找到一个14K star的前端解析插件 github传送门 官方也有,奈何实在太过于浅薄.于是做了以下整理,避免道友们少 ...

  5. iview中page组件的跳转功能BUG解决方案

    xl_echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!! 在 ...

  6. Netty学习(二)-Helloworld Netty

    这一节我们来讲解Netty,使用Netty之前我们先了解一下Netty能做什么,无为而学,岂不是白费力气! 1.使用Netty能够做什么 开发异步.非阻塞的TCP网络应用程序: 开发异步.非阻塞的UD ...

  7. react-native 入门基础介绍

    目录 安装 项目 主要目录结构 入口 Home模块 Coobook模块 List模块 novel模块 相关参考 一个简单的demo,用于介绍react-native相关基础信息,主要是针对有兴趣的同学 ...

  8. XAMPP/LAMPP到底在哪里启用APACHE2的rewrite

    XAMPP/LAMPP是一套我们在个人建站过程中非常便捷常用的集成环境.特别是对于学习PHP开发和建站非常便捷. 最近在使用CentOS7环境下的XAMPP过程中,遇到了一个问题,也就是apache2 ...

  9. (三)(1)线程间通信---wait和notify的使用

    这篇博客记录线程间通信相关api使用以及理解. 首先第一点,我之前的博客里的线程之间也是通信的,但是他们的通信是建立在访问的是同一个变量上的,相当于是变量.数据层面上的通信,而下面要讲的是线程层面上的 ...

  10. 教你如何认识人脸识别开发套件中的双目摄像、3D结构光摄像头、单目摄像头的区别及详细讲解

    深圳市宁远电子提供的人脸识别模组可支持双目摄像头和3D结构光摄像头,在客户咨询中经常有被问到双目的为什么会比单目的成本高,区别在哪里,他们的适用于哪些场景呢?在此,深圳市宁远电子技术工程师就为大家详细 ...