uva 10054 - The Necklace

简介: 点击打开链接uva 10054 思路: 欧拉回路 分析: 1 对于一个无向图来说如果这个图是一个欧拉图,那么必须满足该图是连通的并且每个点的度数都是偶数 2 题目给定n条边的无向图问我们是否是一个欧拉图,是的话输出欧拉图的一条路径 3 ...

点击打开链接uva 10054

思路: 欧拉回路
分析:
1 对于一个无向图来说如果这个图是一个欧拉图,那么必须满足该图是连通的并且每个点的度数都是偶数
2 题目给定n条边的无向图问我们是否是一个欧拉图,是的话输出欧拉图的一条路径
3 首先我们先判断是否所有点的度数都是偶数,然后我们去判断当前图是否是只有一个连通分支,那么这个利用并查集即可
4 如果都满足的话直接去搜索并且输出路径即可

代码:

#include<stack>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;

const int MAXN = 55;
int father[MAXN] , degree[MAXN];
int n , mat[MAXN][MAXN];

void init(){
    memset(mat , 0 , sizeof(mat));
    memset(degree , 0 , sizeof(degree));
    for(int i = 0 ; i < MAXN ; i++)
        father[i] = i;
}

int find(int x){
    if(x != father[x])
       father[x] = find(father[x]);
    return father[x];
}

bool isOk(){
    int root = -1;
    for(int i = 0 ; i < MAXN ; i++){
       if(degree[i]&1)
          return false;
       if(degree[i]){
          if(root == -1)
             root = find(i); 
          else{
             if(root != find(i)) 
                return false;
          } 
       }
    }
    return true;
}

void dfs(int cur){
    for(int i = 1 ; i < MAXN ; i++){
       if(mat[cur][i]){
          mat[cur][i]--;
          mat[i][cur]--;
          dfs(i);
          printf("%d %d\n" , i , cur); 
       }   
    }
}


int main(){
    int Case = 1 , T , x , y , start;
    bool isFirst = true;
    scanf("%d" , &T);
    while(T--){
         scanf("%d" , &n);
         init();
         for(int i = 0 ; i < n ; i++){
            scanf("%d%d", &x , &y); 
            start = x;
            mat[x][y]++;
            mat[y][x]++;
            degree[x]++;
            degree[y]++;
            father[find(x)] = find(y); 
         }
         if(isFirst)
            isFirst = false;
         else
            printf("\n");
         printf("Case #%d\n" , Case++);
         if(!isOk())
             printf("some beads may be lost\n");
         else
             dfs(start);
    }
    return 0;
}




目录
相关文章
|
Linux Android开发 iOS开发
建议收藏!8款音乐APP,找不到喜欢的,算我输!
最近一段时间,有不少同学反复询问我音乐相关的软件。 在以前的文章中,我先后介绍过很多音乐相关的APP,其中不乏一时之间让我非常惊艳的。
建议收藏!8款音乐APP,找不到喜欢的,算我输!
|
存储 Java Nacos
Seata常见问题之springboot 2.3.7 和高版本 seata 2.0.0,1.6.1不兼容如何解决
Seata 是一个开源的分布式事务解决方案,旨在提供高效且简单的事务协调机制,以解决微服务架构下跨服务调用(分布式场景)的一致性问题。以下是Seata常见问题的一个合集
1531 0
|
数据采集 存储 Java
Anaconda安装使用以及Pycharm教程
Anaconda环境基本使用以及与Pycharm集成
2255 0
Anaconda安装使用以及Pycharm教程
|
6月前
|
API
阿里云百炼:零门槛一键搭建 DeepSeek-R1 满血版
本文介绍如何使用阿里云百炼平台和chatbox客户端,一键搭建DeepSeek R1满血版
605 18
|
9月前
|
人工智能 自然语言处理 算法
Qwen-Coder:通过Qwen 2.5模型实现智能代码生成的技术实践
Qwen-Coder:通过Qwen 2.5模型实现智能代码生成的技术实践
|
12月前
|
大数据
用wordcloud搞词云,大数据词云,自定义图像
用wordcloud搞词云,大数据词云,自定义图像
|
存储 缓存 NoSQL
Redis面试题总结(超详细)
Redis面试题总结(超详细)
538 3
|
缓存 小程序
微信小程序解决wx.getUserProfile is not a function 问题
微信小程序解决wx.getUserProfile is not a function 问题
371 4
|
编解码 文字识别 计算机视觉
寒武纪1号诞生:谢赛宁Yann LeCun团队发布最强开源多模态LLM
【7月更文挑战第10天】【寒武纪1号】- 谢赛宁、Yann LeCun团队发布开源多模态LLM,含8B至34B规模模型,创新空间视觉聚合器(SVA)提升视觉-语言集成,建立新基准CV-Bench及大规模训练数据集Cambrian-7M。在多模态任务中表现出色,尤其在高分辨率图像处理上,但面临高分辨率信息处理和部分视觉任务评估的局限。[链接](https://arxiv.org/pdf/2406.16860)
360 1
|
SpringCloudAlibaba Cloud Native 安全
SpringCloudAlibaba:4.2云原生网关higress的基本使用
SpringCloudAlibaba:4.2云原生网关higress的基本使用
435 0