UVa 10004:Bicoloring
这道题要我们判断所给图是否可以用两种颜色进行染色,即"二染色“。已知所给图一定是强连通图。
分析之:
若图中无回路,则该图是一棵树,一定可以二染色。
若图中有回路,但回路有偶数个节点,仍然可以二染色。
仅当图中存在回路且回路有奇数个节点时,不能二染色。
具体实现细节我在代码中给出了详细的注释,我的解题代码如下:
/*
关键在于:当且仅当存在奇回路时,无法二染色
*/
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <string>
#include <algorithm>
using namespace std; int adj[200][200]; //邻接矩阵
int set[200]; //标记图中点所在集合序号
int vis[200]; //标记find中是否已搜索过该点
int n,l; int find(int sour, int obj)
{//在图上从点sour出发搜索obj,如果两者距离为偶返回0,为奇返回1
vis[sour]=1;
if(sour==obj) return 0;
for(int i=0; i<n; i++)
if(adj[i][sour] && !vis[i]) return 1-find(i,obj);
} int main()
{ int ta,tb;
while(cin >> n && n!=0)
{
cin >> l;
memset(adj,0,sizeof(adj));
memset(set,0,sizeof(set));
int ok=1;
for(int i=0; i<l; i++)
{
cin >> ta >> tb;
if(ok)
{
if(set[ta] && set[tb]) //输入的相邻两点原先就在某个集合中
{
if(set[ta]==set[tb]) //输入的相邻两点所在集合相同,则用find搜索
{
memset(vis,0,sizeof(vis));
if(!find(ta,tb)) { ok=0;} //若返回0,则ta,tb两点将构成奇数个节点的回路,无法二染色
}
else
{
for(int j=0; j<n; j++) if(set[j]==set[tb]) //输入的相邻两点所在集合不同,且并未产生偶节点数的回路,则将其中一集合的序号全部改为与另一集合相同
set[tb]=set[ta];
}
}
else if(!set[ta] && !set[tb]) //输入的两点原先均未标记所在集合,则标记之
{
set[ta]=set[tb]=ta+1; //没有使用=ta是因为如果那样,ta=0时set[ta],set[tb]将不产生变化
}
else if(!set[ta]) //只有ta未标记,则用tb标记ta
{
set[ta]=set[tb];
}
else if(!set[tb]) //同上
{
set[tb]=set[ta];
}
adj[ta][tb]=adj[tb][ta]=1;
}
}
if(ok) cout << "BICOLORABLE.\n";
else cout << "NOT BICOLORABLE.\n";
}
return 0;
}
UVa 10004:Bicoloring的更多相关文章
- UVA 10004 Bicoloring
题目链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=12&pa ...
- UVA - 10004 Bicoloring(判断二分图——交叉染色法 / 带权并查集)
d.给定一个图,判断是不是二分图. s.可以交叉染色,就是二分图:否则,不是. 另外,此题中的图是强连通图,即任意两点可达,从而dfs方法从一个点出发就能遍历整个图了. 如果不能保证从一个点出发可以遍 ...
- UVA 10004 Bicoloring(DFS染色)
题意: 给N个点构成的无环无向图,并且保证所有点对都是连通的. 给每个点染色,要么染成黑要么染成白.问是否存在染色方案使得所有有边相连的点对颜色一定不一样. 是输出 BICOLORABLE 否则输出 ...
- uva 10004 Bicoloring(dfs二分染色,和hdu 4751代码差不多)
Description In the ``Four Color Map Theorem" was proven with the assistance of a computer. This ...
- Bicoloring UVA - 10004 二分图判断
\(\color{#0066ff}{题目描述}\) 多组数据,n=0结束,每次一个n,m,之后是边,问你是不是二分图 \(\color{#0066ff}{输入样例}\) 3 3 0 1 1 2 2 0 ...
- UVA 12950 : Even Obsession(最短路Dijkstra)
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVa 10480:Sabotage (最小割集)
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVA 156:Ananagrams (vector+map+sort)
题意:一大堆单词中间有空格隔开,以'#'结束输出,问只出现一次的的单词有哪些(如果两个具有相同的长度,相同的字母也算是相同的,不区分大小写,如:noel和lone属于一个单词出现两次).最后按照字典序 ...
- UVA 10815:Andy's First Dictionary(STL)
题意:给出一段英文,里面包含一些单词,空格和标点,单词不区分大小写,默认都为小写.按照字典序输出这些单词(这些单词不能有重复,字母全部变成小写) stringstream:包含在头文件#include ...
随机推荐
- Spark源码阅读(1): Stage划分
Spark中job由action动作生成,那么stage是如何划分的呢?一般的解答是根据宽窄依赖划分.那么我们深入源码看看吧 一个action 例如count,会在多次runJob中传递,最终会到一个 ...
- 【Unity3D】模仿制作“神庙逃亡”吃金币后金币飞出屏幕效果
[前言] 玩过“神庙逃亡”的应该都知道,这款游戏不论从游戏流畅度.人物动画.场景的管理都很棒. 自己也做了一款简单的跑酷游戏,实现了简单的吃金币效果,但是发现不好看,于是就想模仿“神庙逃亡”中的这个效 ...
- 剖析OkHttp缓存机制
现在应用市场上的 App 无一不需要网络操作,这些应用的开发者大多数都选择结合使用 OkHttp 和 Retrofit 来完成网络操作.okHttp 最为人称道的一个特性就是它的缓存机制,而我将在本篇 ...
- 安装sass时,gem在国内不能安装的解决
最近在安装SASS的时候,用到gem命令,但是运行出行如下错误!(先声明,安装sass前,要保证自己电脑安装了ruby:ruby -v可以测试下有没有装) 原因是ruby 的gem被和谐了,现在淘宝的 ...
- python numpy sum函数用法
numpy.sum numpy.sum(a, axis=None, dtype=None, out=None, keepdims=False)[source] Sum of array element ...
- Shell 的source命令
source命令用法: source FileName 作用:在当前bash环境下读取并执行FileName中的命令. 注:该命令通常用命令“.”来替代. 如:source .bash_rc 与 . ...
- php文件读写锁
$file = fopen("test.txt", $fileOpenMode); flock($file, $lockMode) or die("Can't lock& ...
- iOS 开发者必不可少的 75 个工具,你都会了吗
如果你去到一位熟练的木匠的工作室,你总是能发现他/她有一堆工具来完成不同的任务. 软件开发同样如此.你可以从软件开发者如何使用工具中看出他水准如何.有经验的开发者精于使用工具.对你目前所使用的工具不断 ...
- hdu 1527 取石子游戏(Wythoff Game)
题意:Wythoff Game 思路:Wythoff Game #include<iostream> #include<stdio.h> #include<math.h& ...
- html --- canvas --- javascript --- 在线画板
canvas功能十分强大,制作一个简易画板易如反掌,主要涉及canvas的画线能力,javascript鼠标点击事件 如有问题请参考:http://www.html5party.com/857.htm ...