当前位置: 首页 > news >正文

【PTA数据结构 | C语言版】哥尼斯堡的“七桥问题”

本专栏持续输出数据结构题目集,欢迎订阅。

文章目录

    • 题目
    • 代码

题目

哥尼斯堡是位于普累格河上的一座城市,它包含两个岛屿及连接它们的七座桥,如下图所示。

在这里插入图片描述

可否走过这样的七座桥,而且每桥只走过一次?瑞士数学家欧拉(Leonhard Euler,1707—1783)最终解决了这个问题,并由此创立了拓扑学。

这个问题如今可以描述为判断欧拉回路是否存在的问题。欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路。现给定一个无向图,问是否存在欧拉回路?

输入格式:
输入第一行给出两个正整数,分别是节点数 n (1≤n≤1000)和边数 m;随后的 m 行对应 m 条边,每行给出一对正整数,分别是该条边直接连通的两个节点的编号(节点从1到 n 编号)。

输出格式:
若欧拉回路存在则输出 1,否则输出 0。

输入样例1:
6 10
1 2
2 3
3 1
4 5
5 6
6 4
1 4
1 6
3 4
3 6

输出样例1:
1

输入样例2:
5 8
1 2
1 3
2 3
2 4
2 5
5 3
5 4
3 4

输出样例2:
0

代码

#include <stdio.h>
#include <stdlib.h>#define MAX_N 1000// 邻接表节点结构
typedef struct Node {int vertex;struct Node* next;
} Node;// 并查集结构
typedef struct {int parent[MAX_N + 1];int rank[MAX_N + 1];
} UnionFind;// 初始化并查集
void initUnionFind(UnionFind* uf, int n) {for (int i = 1; i <= n; i++) {uf->parent[i] = i;uf->rank[i] = 1;}
}// 查找根节点并路径压缩
int find(UnionFind* uf, int x) {if (uf->parent[x] != x) {uf->parent[x] = find(uf, uf->parent[x]);}return uf->parent[x];
}// 合并两个集合
void unionSets(UnionFind* uf, int x, int y) {int xRoot = find(uf, x);int yRoot = find(uf, y);if (xRoot == yRoot) return;if (uf->rank[xRoot] < uf->rank[yRoot]) {uf->parent[xRoot] = yRoot;} else if (uf->rank[xRoot] > uf->rank[yRoot]) {uf->parent[yRoot] = xRoot;} else {uf->parent[yRoot] = xRoot;uf->rank[xRoot]++;}
}int main() {int n, m;scanf("%d %d", &n, &m);// 记录每个顶点的度数int degree[MAX_N + 1] = {0};// 初始化并查集UnionFind uf;initUnionFind(&uf, n);// 处理每条边for (int i = 0; i < m; i++) {int u, v;scanf("%d %d", &u, &v);// 更新度数degree[u]++;degree[v]++;// 合并两个顶点所在的集合unionSets(&uf, u, v);}// 检查所有边是否在同一个连通分量中int root = -1;int hasEdge = 0;for (int i = 1; i <= n; i++) {if (degree[i] > 0) {hasEdge = 1;if (root == -1) {root = find(&uf, i);} else if (find(&uf, i) != root) {// 存在多个连通分量printf("0\n");return 0;}}}// 如果没有边,特殊处理if (!hasEdge) {printf("0\n");return 0;}// 检查所有顶点的度数是否为偶数for (int i = 1; i <= n; i++) {if (degree[i] % 2 != 0) {printf("0\n");return 0;}}// 所有条件满足,存在欧拉回路printf("1\n");return 0;
}    
http://www.dtcms.com/a/291197.html

相关文章:

  • 【ROS1】07-话题通信中使用自定义msg
  • (9)机器学习小白入门 YOLOv:YOLOv8-cls 技术解析与代码实现
  • 选择排序 冒泡排序
  • LinkedList与链表(单向)(Java实现)
  • android studio 远程库编译报错无法访问远程库如何解决
  • 算法提升之字符串回文问题-(马拉车算法)
  • Java基础教程(011):面向对象中的构造方法
  • 模拟高负载测试脚本
  • Flink框架:keyBy实现按键逻辑分区
  • 250kHz采样率下多信号参数设置
  • mysql-5.7 Linux安装教程
  • 无人机报警器技术要点与捕捉方式
  • Anaconda 路径精简后暴露 python 及工具到环境变量的配置记录 [二]
  • Linux学习之Linux系统权限
  • scratch音乐会开幕倒计时 2025年6月中国电子学会图形化编程 少儿编程 scratch编程等级考试一级真题和答案解析
  • Git核心功能简要学习
  • 知识 IP 的突围:从 “靠感觉” 到 “系统 + AI” 的变现跃迁
  • 网络编程及原理(八)网络层 IP 协议
  • 关于校准 ARM 开发板时间的步骤和常见问题:我应该是RTC电池没电了才导致我设置了重启开发板又变回去2025年的时间
  • Xilinx FPGA XCKU115‑2FLVA1517I AMD KintexUltraScale
  • 【Java EE】多线程-初阶-Thread 类及常见方法
  • Netty中CompositeByteBuf 的addComponents方法解析
  • PNP加速关断驱动电路
  • [数据结构]#4 用链表实现的栈结构
  • FastAPI 中,数据库模型(通常使用 SQLAlchemy 定义)和接口模型(使用 Pydantic 定义的 schemas)的差异
  • GraphRAG快速入门和原理理解
  • 在线教育如何设置视频问答/视频弹题?——重塑在线教育的互动体验
  • 元宇宙工厂漫游指南:VR可视化在设备巡检与远程运维中的沉浸式应用
  • Component cannot be used as a JSX component
  • 网络数据编码技术及其应用场景的全面解析