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 ...
随机推荐
- android面试题之七
三十六.请解释下在单线程模型中Message.Handler.Message Queue.Looper之间的关系. 简单的说,Handler获取当前线程中的looper对象,looper用来从存放Me ...
- HashSet的分析(转)
一. HashSet概述: HashSet实现Set接口,由哈希表(实际上是一个HashMap实例)支持.它不保证set 的迭代顺序:特别是它不保证该顺序恒久不变.此类允许使用null元素. 二. ...
- (转).net程序员转战android第三篇---登录模块之静态登录
这一篇我将分2个部分记录登录界面,第一部分是静态登录, 这部分将如何从界面布局.控件使用.文件关系.数据验证.登陆实现等5小块记录. 第二部分是动态登录,这块会基于上面的4小块,在数据验证不是静态数据 ...
- Oracle 账户被锁定
哎 每次安装oracle的时候总是忘了将用户解锁,结果就蛋疼了,从网上找到一个简单的解决方案 在CMD命令输出如下: sqlplus /nolog alert user system account ...
- poj3579 二分搜索+二分查找
Median Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 5468 Accepted: 1762 Descriptio ...
- 关于extern对变量的使用
extern 是声明全局的变量的意思. 例如在一个工程中有两个cpp,一个是test.cpp一个是main.cpp . 我们在test.cpp中定义了一个int num;但是我们在main.cpp中想 ...
- #能力开放平台系列-Fiddler访问Rest服务
问题 最近开发能力开放平台,需要将Dubbo服务转换成Rest服务,虽然转换很成功(后续文档会写出如何将Dubbo服务转换成Rest接口),但是调试起来特别的麻烦. 解决方案: Fiddler解决方案 ...
- 初学 Play Framework 以及可能遇到的问题
这段话之后都是我从别人那拷贝过来的资料,方便大家查阅 红色标注字体是我自己遇到的一些问题: 如果你遇到了这样的问题 :
- Java 中字符串的子串搜索
基友前两天参加了阿里的实习生面试,问了个问题,就是关于字符串的子串搜索的问题.想想实现方式无非就是两层循环,但是 java 中是有现成实现的,于是我就去查查源码,看看 java 语言怎么实现这个的,发 ...
- 【笔记】shell下的主要工具
shell 下有很多工具是非常好的辅助. 一.自我精进的途径 1.help / --help :简要的帮助说明: help 是针对 shell 内建功能的帮助, gnu工具一般为 "程序名 ...