前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >POJ–1300–Door Man【推断无向图欧拉通路】

POJ–1300–Door Man【推断无向图欧拉通路】

作者头像
全栈程序员站长
发布2022-07-08 17:33:12
2150
发布2022-07-08 17:33:12
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是全栈君。

链接:http://poj.org/problem?id=1300

题意:有n个房间。每一个房间有若干个门和别的房间相连。管家从m房间開始走。要回到自己的住处(0),问是否有一条路能够走遍全部的门而且没有反复的路。

无向图欧拉通路充要条件:G为连通图,而且G仅有两个奇度结点(度数为奇数的顶点)或者无奇度结点。

无向图欧拉回路充要条件:G为无奇度结点的连通图。

思路:推断是否存在欧拉通路。依据欧拉通路、欧拉回路的性质来做。有两种情况:一种是欧拉回路。全部房间的门的个数都是偶数个,而且此时初始房间不是0,此时存在要求的路径。假设初始是0则不行。还有一种是欧拉通路。仅仅有两个房间门是奇数个。剩下都是偶数个。而且这两个房间一个是0。一个是当前起点,而且起点不能是0,此时也存在要求的路径,否则不存在。

输入比較蛋疼

代码语言:javascript
复制
#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|1

int 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;
}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/116070.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年1月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档