系统的学习一遍图论!从这篇博客开始!

先介绍一些概念。

无向图:

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 欧拉通路&欧拉回路的更多相关文章

  1. HDU 5883 F - The Best Path 欧拉通路 & 欧拉回路

    给定一个图,要求选一个点作为起点,然后经过每条边一次,然后把访问过的点异或起来(访问一次就异或一次),然后求最大值. 首先为什么会有最大值这样的分类?就是因为你开始点选择不同,欧拉回路的结果不同,因为 ...

  2. 欧拉回路&欧拉通路判断

    欧拉回路:图G,若存在一条路,经过G中每条边有且仅有一次,称这条路为欧拉路,如果存在一条回路经过G每条边有且仅有一次, 称这条回路为欧拉回路.具有欧拉回路的图成为欧拉图. 判断欧拉通路是否存在的方法 ...

  3. poj 2513 连接火柴 字典树+欧拉通路 好题

    Colored Sticks Time Limit: 5000MS   Memory Limit: 128000K Total Submissions: 27134   Accepted: 7186 ...

  4. Colored Sticks POJ - 2513 并查集+欧拉通路+字典树hash

    题意:给出很多很多很多很多个棒子 左右各有颜色(给出的是单词) 相同颜色的可以接在一起,问是否存在一种 方法可以使得所以棒子连在一起 思路:就是一个判欧拉通路的题目,欧拉通路存在:没奇度顶点   或者 ...

  5. POJ 2513 无向欧拉通路+字典树+并查集

    题目大意: 有一堆头尾均有颜色的木条,要让它们拼接在一起,拼接处颜色要保证相同,问是否能够实现 这道题我一开始利用map<string,int>来对颜色进行赋值,好进行后面的并查操作以及欧 ...

  6. POJ 1386 Play on Words(有向欧拉通路 连通图)

    题意  见下方中文翻译 每一个单词能够看成首尾两个字母相连的一条边  然后就是输入m条边  推断是否能构成有向欧拉通路了 有向图存在欧拉通路的充要条件: 1. 有向图的基图连通: 2. 全部点的出度和 ...

  7. POJ 1300 Door Man(欧拉回路的判定)

    题目链接 题意 : 庄园有很多房间,编号从0到n-1,能否找到一条路径经过所有开着的门,并且使得通过门之后就把门关上,关上的再也不打开,最后能回到编号为0的房间. 思路 : 这就是一个赤裸裸的判断欧拉 ...

  8. poj2513- Colored Sticks 字典树+欧拉通路判断

    题目链接:http://poj.org/problem?id=2513 思路很容易想到就是判断欧拉通路 预处理时用字典树将每个单词和数字对应即可 刚开始在并查集处理的时候出错了 代码: #includ ...

  9. hdu1116有向图判断欧拉通路判断

    Play on Words Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) T ...

随机推荐

  1. DDMS files not found: tools\hprof-conv.exe

    最近在Eclipse下每次更新ADT和SDK后都报一些错误,比如 DDMS files not found: D:\android-sdk-windows-1.6_r1\android-sdk-win ...

  2. Dynamics CRM 2016 使用Plug-in Trace Log调试插件

    1.写插件 首先,让我们写一个简单的插件来测试新插件跟踪日志功能.请注意,在下面的示例代码中,我们增加ITracingService的一个实例,以及记录有关插件的执行信息记录的一些键值: 2.注册插件 ...

  3. Internetmap.apk实现原理分析

    1.本地实现调用 程序根据data文件目录下的asinfo.json文件(包含自治域网络名和对应的坐标值),调用so文件绘制asn结点图(ASN,AutoSystemNode,自治域结点) 2.路由查 ...

  4. c#转码解码

    ///反转码                          mdata[k].MNAME = unescape(mdata[k].MNAME);程家楠 13:51:00 Microsoft.JSc ...

  5. Android Studio ---------------常用快捷键(更新中。。。。。。)

    ##常用快捷键: Ctrl+X(或Y) 删除行 Ctrl+D 复制行 Ctrl+Alt+L 格式化代码 Ctrl + Alt + V 提取变量 Shift+F6 重命名 Ctrl+F12显示当前文件的 ...

  6. ios开发必备第三方库

    引言 作为iOS开发人员,在开发App的过程中怎么会不使用第三方库呢?相信没有App是不使用第三方库的! 网络库 网络库,这是开发必备,除非你的App玩单机.现在特别火也特别好用的网络库就数AFNet ...

  7. 整理 C#(同步调用、异步调用、异步回调)

    //闲来无事,巩固同步异步方面的知识,以备后用,特整理如下: class Program { static void Main(string[] args) { //同步调用 会阻塞当前线程,一步一步 ...

  8. hdu4296 贪心

    E - 贪心 Crawling in process... Crawling failed Time Limit:2000MS     Memory Limit:32768KB     64bit I ...

  9. angular.js学习

    1.第一个小例子 <!DOCTYPE html> <html> <body> <div ng-app=""> <p>在输 ...

  10. web api简单验证实现办法

    需要使用WEBAPI,但是有验证问题没解决.后来参考网上文章做了一下DEMO 思路: 就是根据用户的账号在服务端加密一个字符串,然后返回给用户端. 具体: 一个用户编号用于唯一身份识别,密码,一个密钥 ...