POJ--1300--Door Man【判断无向图欧拉通路】
来源:互联网 发布:mac可以下载flash吗 编辑:程序博客网 时间:2024/05/22 02:38
链接:http://poj.org/problem?id=1300
题意:有n个房间,每个房间有若干个门和别的房间相连,管家从m房间开始走,要回到自己的住处(0),问是否有一条路可以走遍所有的门并且没有重复的路。
无向图欧拉通路充要条件:G为连通图,并且G仅有两个奇度结点(度数为奇数的顶点)或者无奇度结点。
无向图欧拉回路充要条件:G为无奇度结点的连通图。
思路:判断是否存在欧拉通路,根据欧拉通路、欧拉回路的性质来做。有两种情况:一种是欧拉回路,所有房间的门的个数都是偶数个,并且此时初始房间不是0,此时存在要求的路径,如果初始是0则不行。另一种是欧拉通路,只有两个房间门是奇数个,剩下都是偶数个,并且这两个房间一个是0,一个是当前起点,并且起点不能是0,此时也存在要求的路径,否则不存在。
输入比较蛋疼
#include<cstring>#include<string>#include<fstream>#include<iostream>#include<iomanip>#include<cstdio>#include<cctype>#include<algorithm>#include<queue>#include<map>#include<set>#include<vector>#include<stack>#include<ctime>#include<cstdlib>#include<functional>#include<cmath>using namespace std;#define PI acos(-1.0)#define MAXN 500100#define eps 1e-7#define INF 0x7FFFFFFF#define LLINF 0x7FFFFFFFFFFFFFFF#define seed 131#define mod 1000000007#define ll long long#define ull unsigned ll#define lson l,m,rt<<1#define rson m+1,r,rt<<1|1int in[30],out[30];char s[20],s1[200];int main(){ int i,j; int m,n; int a,flag,ans,fk; while(scanf("%s",s)!=EOF){ if(s[0]=='E'&&strlen(s)>5) break; scanf("%d%d",&m,&n); getchar(); ans = 0; flag = 0; fk = 0; memset(in,0,sizeof(in)); for(i=0;i<n+1;i++){ gets(s1); int p = 0; while(sscanf(s1+p,"%d",&a)==1){ ans++; in[a]++; in[i]++; while(s1[p]!='\0'&&s1[p]!=' ') p++; while(s1[p]!='\0'&&s1[p]==' ') p++; } } for(i=0;i<n;i++){ if(in[i]&1) flag++; } if(!flag){ if(!m) fk = 1; else fk = 0; } else{ if(flag==2&&m!=0&&in[m]&1&&in[0]&1) fk = 1; else fk = 0; } if(fk) printf("YES %d\n",ans); else puts("NO"); } return 0;}
0 0
- POJ--1300--Door Man【判断无向图欧拉通路】
- poj 1300 Door Man 无向图欧拉路径存在判断
- POJ 1300 Door Man (有向图欧拉通路)
- POJ 1300 Door Man(欧拉通路)
- POJ 2513 - Colored Sticks 判断无向图哈密顿通路转化为判断无向图欧拉通路
- poj 1300 Door Man
- POJ-1300-Door Man
- Door Man poj 1300
- POJ 1300 Door Man
- poj Door Man(1300)
- POJ-1300 Door Man
- poj 1300 Door Man
- POJ-1300 Door Man
- Poj 1300 Door Man (欧拉回路 通路 stream处理输入)
- [欧拉图] poj 1300 Door Man
- POJ 1300 Door Man 笔记
- 无向图欧拉通路
- POJ 1300 Door Man - from lanshui_Yang
- UVALive 4730 Kingdom 线段树+并查集
- perl hash 和 map 新理解
- 数据库管理系统DBMS之缓存管理
- 使用SVNChina来保管eclipse的代码
- FreeRTOS代码剖析之1:内存管理Heap_1.c
- POJ--1300--Door Man【判断无向图欧拉通路】
- spnego 配置心得
- 百度UEditor组件出现Parameters: Invalid chunk '' ignored警告的分析
- 学习小结1<下载的几种方式>
- java设计模式——结构型模式专题(二)适配器模式
- 医疗时鲜资讯:第二十三届中国国际医用仪器设备展览会暨技术交流会 有感
- Linux实战4——安装IntelliJ IDEA
- php学习笔记7--服务器变量 $_SERVER 详解
- Servlet请求转发之RequestDispatcher