一笔画问题的c++实现
来源:互联网 发布:二维码批量打印软件 编辑:程序博客网 时间:2024/05/16 01:36
一笔画问题,即欧拉回路问题,最近在算法课上老师留了这个作业,下面将我的实现说一下。首先,先将问题描述一下。
该图中节点编号从上至下,从左至右编号如下
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:感谢杨老师的算法课,这位老教授的课很有趣,我也收获了很多。
- 一笔画问题的c++实现
- 一笔画的问题
- 一笔画问题
- 一笔画问题
- 一笔画问题
- nyoj_42 一笔画问题
- NYOJ42 一笔画问题
- NYOJ42-一笔画问题
- NYOJ 一笔画问题
- 一笔画问题 nyist42
- nyoj42一笔画问题
- 一笔画问题
- 一笔画问题
- nyoj42 一笔画问题
- 一笔画问题
- NYOJ42-一笔画问题
- NYOJ42一笔画问题
- 一笔画问题
- 第一次来写博客
- 睡眠与养生
- Facebook更像Google还是更像Yahoo?
- c/c++链表操作
- 08年团队拓展培训杂记
- 一笔画问题的c++实现
- The Fountain Effect 喷泉效果
- 第一次使用g++
- 关于socket编程详细的讲解
- Advanced English Note--AD030301
- eclipse打开当前文件所在文件夹的两种方法
- Some simple facts about XML (二)
- 隐藏快捷方式扩展名(.lnk)
- test