- 1、本文档共30页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于紧缩图的拓扑排序
2013-1-18
东北大学信息科学与工程学院
数据结构课程设计报告
题目 基于紧缩图的拓扑排序
课题组长 刘正皓
课题组成员 杨绍伟 杨冰
专业名称 计算机科学与技术
班级 计1208
指导教师 杨雷
2014 年 1月
课程设计任务书
题目:
基于紧缩图的拓扑排序 问题描述:
紧缩邻接表将图的每个顶点的邻接表紧凑的存储在两个向量list和h中。其中向量list依次存储顶点0,1,…,n-1的邻接顶点。向量单元h[i]存储顶点i的邻接表在向量list中的起始位置。
设计要求:
设计基于紧缩图的邻接表的拓扑排序程序。
(1)采用STL的图、栈等数据结构。
(2)实现STL的紧缩邻接表结构图类。
(3)实现紧缩图的邻接表结构的拓扑排序。
指导教师签字:
2013年12月15日
目录
1 课题概述 1
1.1 课题任务 1
1.2 课题原理 1
1.3 相关知识 2
2 需求分析 2
2.1 课题调研 3
2.2 用户需求分析 3
3 方案设计 4
3.1 总体功能设计 4
3.2 数据结构设计 4
3.3 函数原型设计 5
3.4 主算法设计 5
3.5 用户界面设计 5
4 方案实现 6
4.1 开发环境与工具 6
4.2 程序设计关键技术 6
4.3 个人设计实现(按组员分工)
4.3.1 刘正皓设计实现 7
4.3.2 杨绍伟设计实现 11
4.3.3 杨冰设计实现 12
5 测试与调试 13
5.1 个人测试(按组员分工) 13
5.1.1 刘正皓测试 13
5.1.2 杨绍伟测试 16
5.1.3 杨冰测试 19
5.2 组装与系统测试 20
5.3 系统运行 20
6 课题总结 21
6.1 课题评价 22
6.2 团队协作 22
6.3 个人设计小结(按组员分工) 22
6.3.1 刘正皓设计小结 22
6.3.2 杨绍伟设计小结 22
6.3.3 杨冰设计小结 23
7 附录A 课题任务分工 50
A-1 课题程序设计分工 50
A-2 课题报告分工 51
附录B 课题设计文档(光盘)
B-1课程设计报告(电子版)
B-2源程序代码(*.H,*.CPP)
B-3工程与可执行文件)
B-4屏幕演示录像文件(可选) 52
附录C 用户操作手册(可选) 31
C.1 运行环境说明 31
C.2 操作说明 31
1课题概述
课题任务
以STL类模板实现紧缩图邻接表的拓扑排序
课题原理
将图的结点存入两个向量之中,List用以存放全部结点,H用以存放结点间的相互关联关系,通过输入一系列结点信息及其发出弧的信息,确定每个结点的入度,进行拓扑排序序列的输出。拓扑排序算法bool TopologicalSort(ALGraph G) 中,先输出入度为零的顶点,而后输出新的入度为零的顶点,此操作可利用栈实现。该算法大体思想为:
1)遍历有向图各顶点的入度,将所有入度为零的顶点入栈;
2)栈非空时,输出一个顶点,并对输出的顶点数计数;
3)该顶点的所有邻接点入度减一,若减一后入度为零则入栈;
4)重复2)、3),直到栈为空,若输出的顶点数与图的顶点数相等则该图可拓扑排序,否则图中有环。
流程图如下:
相关知识
STL中的向量模板,通过栈实现图的拓扑排序。
2需求分析
2.1 课题调研
通常,这样的线性序列称为满足拓扑次序(Topological Order)的序列,简称拓扑序列。简单的说,由某个集合上的一个偏序得到该集合上的一个全序,这个操作称之为拓扑排序。离散数学中关于偏序和全序的定义:
若集合X上的关系是R,且R是自反的、反对称的和传递的,则称R是集合X上的偏序关系。
设R是集合X上的偏序(Partial Order),如果对每个x,y属于X必有xRy 或 yRx,则称R是集合X上的全序关系。
比较简单的理解:偏序是指集合中只有部分成员可以比较,全序是指集合中所有的成员之间均可以比较。
用户可以通过输入每个结点和弧的信息讲结点放入图中,再通过栈实现拓扑排序序列的输出;
可以在拓扑排序时同时输出结点信息;
该程序应该有对用户错误输入的辨别纠错功能;
程序应具有演示功能和调试功能。
程序应具有良好的人机接口。程序应能所见即所得的输入数据。这就如同在VS中可视化的开发图形界面一样。程序应能精确的输入数据。每一个点的坐标,每条弧的权值都应能由用户精确控制。这就如同在VS中用代码编辑用户界面一样。
程序应能友好的展现结果。
该程序可以显示时间。
程序应能显示制作者的信息。
3方案设计
3.1 总体功能设计
拓扑排序
参数说明 功能描述 bool TopologicalSort(Graph v,vector int inde
您可能关注的文档
- 城市天然气流量计选用.ppt
- 城市形态空间研究 2.ppt
- 城市管理学简答论述浓缩版.doc
- 城市内部的空间结构文.pptx
- 地震概论-0-绪论.ppt
- 城市管理局政风行风建设汇报材料.ppt
- 城市区位说课.ppt
- 城市规划原理第七章.ppt
- 地震相分析解释与构造解释.doc
- 城市诱导屏方案书.doc
- 2023年江苏省镇江市润州区中考生物二模试卷+答案解析.pdf
- 2023年江苏省徐州市邳州市运河中学中考生物二模试卷+答案解析.pdf
- 2023年江苏省苏州市吴中区中考冲刺数学模拟预测卷+答案解析.pdf
- 2023年江苏省南通市崇川区田家炳中学中考数学四模试卷+答案解析.pdf
- 2023年江西省吉安市中考物理模拟试卷(一)+答案解析.pdf
- 2023年江苏省泰州市海陵区九年级(下)中考三模数学试卷+答案解析.pdf
- 2023年江苏省苏州市高新二中中考数学二模试卷+答案解析.pdf
- 2023年江苏省南通市九年级数学中考复习模拟卷+答案解析.pdf
- 2023年江苏省南通市海安市九年级数学模拟卷+答案解析.pdf
- 2023年江苏省泰州市靖江外国语学校中考数学一调试卷+答案解析.pdf
最近下载
- 2025年高考数学模拟卷(四)含答案及解析.pdf VIP
- 急性呼吸循环衰竭的早期识别与救治(共88张PPT)【88页】.pptx VIP
- 2023年河南省普通高校对口招生考试电子类专业课试卷.pdf VIP
- 院感及院感管理的基本概念.ppt VIP
- 维生素d3与骨骼健康课件.ppt
- 重点项目信息管理平台建设方案.docx
- 2025年高考数学模拟卷(三)含答案及解析.pdf VIP
- 河师大焦争鸣张万琴版线性代数答案解析.pdf VIP
- Unit4NaturalDisastersListeningandSpeaking课件高中英语人教版22.pptx
- 接受人生的荒谬是强大还是懦弱的表现?辩论赛 正方辩词一辩、二辩、三辩、四辩发言稿.docx
文档评论(0)