POJ 1300 欧拉通路&欧拉回路
系统的学习一遍图论!从这篇博客开始!
先介绍一些概念。
无向图:
G为连通的无向图,称经过G的每条边一次并且仅一次的路径为欧拉通路。
如果欧拉通路是回路(起点和终点相同),则称此回路为欧拉回路。
具有欧拉回路的无向图G称为欧拉图。
有向图:
D为基图连通的有向图,则称经过D的每一条边并且仅一次的路径为有向欧拉通路。
如果该通路是回路,则称为有向欧拉回路。
具有有向欧拉回路的有向图D称为有向欧拉图。
无向图判断欧拉通路:G为连通图,且仅有两个奇度的节点或者无奇度节点。
如果有两个奇度的点,那么这两点必定为欧拉通路的起点和终点。
如果没有奇度的节点,那么该图一定有欧拉回路。
有向图判断欧拉通路:D的基图连通,并且所有节点的出度和入度相同,那么该图存在有向欧拉回路。
如果仅有两个节点的出度和入度之差为1和-1,那么该图一定存在欧拉通路,并且一定以入度出度之差为-1的点为起点,入度出度之差为1的点为终点。
/************************************************************以上概念******************************************************************/
接下来介绍这道题。
题意就是能否从一个点出发,经过所有的边,回到节点0。
思路:就是判断一下,如果起点就是0,那么就是求是否存在欧拉回路。
如果起点不是0,那么就是求是否存在欧拉通路,并且欧拉通路的起点终点为0和输入的起点。
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string>
#include <cmath>
#include <cstring>
#include <queue>
#include <set>
#include <vector>
#include <stack>
#include <map>
#include <iomanip>
#define PI acos(-1.0)
#define Max 2505
#define inf 1<<28
#define LL(x) ( x << 1 )
#define RR(x) ( x << 1 | 1 )
#define REP(i,s,t) for( int i = ( s ) ; i <= ( t ) ; ++ i )
#define ll long long
#define mem(a,b) memset(a,b,sizeof(a))
#define mp(a,b) make_pair(a,b)
#define PII pair<int,int>
using namespace std; inline void RD(int &ret) {
char c;
do {
c = getchar();
} while(c < '0' || c > '9') ;
ret = c - '0';
while((c=getchar()) >= '0' && c <= '9')
ret = ret * 10 + ( c - '0' );
}
inline void OT(int a){
if(a >= 10)OT(a / 10) ;
putchar(a % 10 + '0') ;
}
#define N 1111
char in[111] ;
int degree[N] ;
int main() {
while(cin >> in){
if(in[0] == 'E')break ;
mem(degree , 0) ;
int n , m ;
cin >> n >> m ;
getchar() ;
int sum = 0 ;
for (int i = 0 ; i < m ;i ++ ){
int now ;
gets(in) ;
int l = strlen(in) ;
if(!l)continue ;
int num = 0 ;
for (int j = 0 ;j < l ;j ++ ){
if(in[j] == ' '){
degree[i] ++ ;
degree[num] ++ ;
sum ++ ;
num = 0 ;
}
else {
num = num * 10 + (in[j] - '0') ;
}
}
if(num){
degree[i] ++ ;
degree[num] ++ ;
sum ++ ;
}
}
cin >> in ;
int odd = 0 ;
int even = 0 ;
for (int i = 0 ; i < m ; i ++ ){
if(degree[i] & 1)odd ++ ;
else even ++ ;
}
if(!odd){
if(n == 0){
printf("YES %d\n",sum) ;
}
else {
puts("NO") ;
}
}
else {
if(odd == 2){
if((degree[n] & 1) && (degree[0] & 1) && (n != 0)){
printf("YES %d\n" ,sum) ;
}
else {
puts("NO") ;
}
}else {
puts("NO") ;
}
}
}
return 0 ;
}
POJ 1300 欧拉通路&欧拉回路的更多相关文章
- HDU 5883 F - The Best Path 欧拉通路 & 欧拉回路
给定一个图,要求选一个点作为起点,然后经过每条边一次,然后把访问过的点异或起来(访问一次就异或一次),然后求最大值. 首先为什么会有最大值这样的分类?就是因为你开始点选择不同,欧拉回路的结果不同,因为 ...
- 欧拉回路&欧拉通路判断
欧拉回路:图G,若存在一条路,经过G中每条边有且仅有一次,称这条路为欧拉路,如果存在一条回路经过G每条边有且仅有一次, 称这条回路为欧拉回路.具有欧拉回路的图成为欧拉图. 判断欧拉通路是否存在的方法 ...
- poj 2513 连接火柴 字典树+欧拉通路 好题
Colored Sticks Time Limit: 5000MS Memory Limit: 128000K Total Submissions: 27134 Accepted: 7186 ...
- Colored Sticks POJ - 2513 并查集+欧拉通路+字典树hash
题意:给出很多很多很多很多个棒子 左右各有颜色(给出的是单词) 相同颜色的可以接在一起,问是否存在一种 方法可以使得所以棒子连在一起 思路:就是一个判欧拉通路的题目,欧拉通路存在:没奇度顶点 或者 ...
- POJ 2513 无向欧拉通路+字典树+并查集
题目大意: 有一堆头尾均有颜色的木条,要让它们拼接在一起,拼接处颜色要保证相同,问是否能够实现 这道题我一开始利用map<string,int>来对颜色进行赋值,好进行后面的并查操作以及欧 ...
- POJ 1386 Play on Words(有向欧拉通路 连通图)
题意 见下方中文翻译 每一个单词能够看成首尾两个字母相连的一条边 然后就是输入m条边 推断是否能构成有向欧拉通路了 有向图存在欧拉通路的充要条件: 1. 有向图的基图连通: 2. 全部点的出度和 ...
- POJ 1300 Door Man(欧拉回路的判定)
题目链接 题意 : 庄园有很多房间,编号从0到n-1,能否找到一条路径经过所有开着的门,并且使得通过门之后就把门关上,关上的再也不打开,最后能回到编号为0的房间. 思路 : 这就是一个赤裸裸的判断欧拉 ...
- poj2513- Colored Sticks 字典树+欧拉通路判断
题目链接:http://poj.org/problem?id=2513 思路很容易想到就是判断欧拉通路 预处理时用字典树将每个单词和数字对应即可 刚开始在并查集处理的时候出错了 代码: #includ ...
- hdu1116有向图判断欧拉通路判断
Play on Words Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) T ...
随机推荐
- maven plugin在tomcat 热部署
前言: 此处的方法适用于tomcat6 和 tomcat7,对于最新的tomcat8还没有进行过測试,有兴趣的同学能够自己測一下. 总共分为五步: 1.在tomcat中配置用户权限,即 ...
- Linux中图形界面和文本模式相互切换
1.默认开机进入文本模式 如果想让开机自动进纯文本模式, 修改/etc/inittab 找到其中的 id:5:initdefault: 这行指示启动时的运行级是5,也就是图形模式 改成3就是文本模式了 ...
- mysqldump备份原理
现网中数据库运维时,要经常对数据库做热备.为保证恢复时数据的完整性与一致性, 一种方法是在备份之前锁表,但锁表会影响正在运行的业务. mysqldump是当前MySQL中最常用的备份工具,通过mysq ...
- UVA11388 GCD LCM1 2 -1
题目: 给你两个数G和L,求a和b,他们的最大公约数为G和最小公倍数为L,输出a最小时的a和b.如果不存在在输出-1. Sample Input 2 1 2 3 4 Output for Samp ...
- .NET开发人员必须知道的八个网站
对于不熟悉.NET技术的朋友,需要说明一下,.NET提供了一个平台和一些相应的工具,.NET开发人员可以使用它们来在开发Windows桌面,互联网,甚至是手持移动设备上构建极富交互性的应用.很有可能你 ...
- Oracle - SQL 错误: ORA-00917: 缺失逗号
ORACLE SQL语句中int型插入数据库时,不要加引号.
- SqlDbHelper备份,做项目时方便应用(目前不太全,把自己项目中的逐渐转移过来)
****************************************** 这是官网新闻左侧类别那部分用到的 **************************************** ...
- SilverLight 页面后台方法XX.xaml.cs 创建JS,调用JS ,弹出提示框
1.Invoke和InvokeSelf [c-sharp] view plaincopy public partial class CreateJSDemo : UserControl { publi ...
- Unable to open log device '/dev/log/main': No such file or directory
在我们使用真机进行Android应用调试时,无法获得调试信息,错误提示如下:Unable to open log device '/dev/log/main': No such file or dir ...
- 转载--eclipse git插件安装
原文地址:http://yufenfei.iteye.com/blog/1750124/ 一.Eclipse上安装GIT插件EGit Eclipse的版本eclipse-java-helios-SR2 ...