一笔画问题的c++实现

本文介绍了如何使用C++解决一笔画问题,即欧拉回路问题。通过寻找小回路并标记边,从节点1开始,最终找到一笔画的路线。代码中详细解释了算法思路,并给出了具体的实现过程。

一笔画问题,即欧拉回路问题,最近在算法课上老师留了这个作业,下面将我的实现说一下。首先,先将问题描述一下。

 

该图中节点编号从上至下,从左至右编号如下
  1   2
 3 4 5 6
7 8 9 10 11
   12 13
  14 15 16
要求:从节点1开始,一笔将该图形画出。
首先讲下该题的大概思路:
概括的讲是先找小回路,再并小回路。
(1)先将1放入访问队列中,寻找1的未访问过的邻接边,将满足这样条件的边中另一顶点值最小的顶点放入访问队列中,再从这个点出发继续寻找,直至找到的变的另一顶点与队列头部顶点相等(这时说明找到了一条小回路),将找到的第一个小回路的边标记为1;若队列头顶点还存在另一小回路,则继续寻找另一小回路;否则要将队列头结点删除,开始下一点的查找。
(2)将图中所有边都标记后,再从1开始,找与该点邻接的边中值最大的边的另一点,若存在多个边值一样的边,则先从顶点值较小的点开始,并将当前访问的点设置为该点,再往下找。
说了这么多,还是感觉不大明白。用本题的具体数字说明一下。
第一次找小回路1-3-4-1
第二次3-7-8-3
第三次4-8-9-4
第四次9-5-2-6-5-10-6-11-10-9
。。。。。。
在访问队列中存储的节点
1,3,4,7,8,9,5,2,6,10,11,12,13,14,15,16
代码如下

呵呵,讲的可能不是很清楚,有不懂的可以问我,希望大家可以在这探讨。

本题的输入文件的数据是这样的

16 27
1 3
1 4
2 5
2 6
3 4
3 7
3 8
4 8
4 9
5 6
5 9
5 10
6 10
6 11
7 8
8 9
9 10
10 11
9 12
9 13
12 13
12 14
12 15
13 15
13 16
14 15
15 16

第一行中第一个数是点数,第二个数是文件中数据的行数,

以下每一行表示边之间的联通关系。
PS:感谢杨老师的算法课,这位老教授的课很有趣,我也收获了很多。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值