- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
拓扑排序课程设计报告.
数据结构课程设计
设计题目: 有向图拓扑排序
专 业: 信息与计算科学
学 号: 021240616
姓 名: 黄秋实
指导教师: 文 军
2013年11月28日
数据结构课程设计
----拓扑排序
一 需求分析问题描述
用邻接表构造图 然后进行拓扑排序,输出拓扑排序序列
1).从有向图中选一个无前驱的顶点输出;2).将此顶点和以它为起点的弧删除;3). 重复1),2)直到不存在无前驱的顶点;4). 若此时输出的顶点数小于有向图中的顶点数,则说明有向图中存在回路,否则输出的顶点的顺序即为一个拓扑序列。
2. 拓扑排序 有向图拓朴排序算法的基本步骤如下: ①从图中选择一个入度为0的顶点,输出该顶点; ②从图中删除该顶点及其相关联的弧,调整被删弧的弧头结点的入度(入度-1); ③重复执行①、②直到所有顶点均被输出,拓朴排序完成或者图中再也没有入度为0的顶点(此种情况说明原有向图含有环)。
3基本要求
输入的形式和输入值的范围输出的形式;程序所能达到的功能;
二 概要设计
三 详细设计实现概要设计中定义的所有数据类型,对每个操作写出伪码算法对主程序和其他模块也都需要写出伪码算法(伪码算法达到的详细程度建议为按照伪码算法可以在计算机键盘直接输入高级程序设计语言程序);写出出函数和过程的调用关系实现概要设计中定义的所有数据类型#includestdio.h
#includestdlib.h
#define MAX_VEXTEX_NUM 100
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10
#define OK 1
#define M 100
#define ERROR 0
typedef int ElemType;
typedef struct ArcNode
{
int adjvex;
struct ArcNode *nextarc;
}ArcNode;
typedef struct VNode
{
int data;
ArcNode *firstarc;
}VNode,AdjList[MAX_VEXTEX_NUM];
typedef struct
{
AdjList vertices;
int vexnum, arcnum;
}ALGraph;
typedef struct
{
ElemType *base;
ElemType *top;
int stacksize;
}SqStack;
2.算法和各模块的代码
程序中各函数算法思想如下:
void InitStack(SqStack *S)
初始化栈将栈的空间设为 STACK-INIT-SIZE。
int Pop(SqStack *S,ElemType *e)
出栈操作,若站不空,删除S的栈顶元素,用e返回其值,并返回OK;否则返回ERROR。
void Push(SqStack *S,ElemType e)
进栈操作,插入元素e为新的栈顶元素。
int StackEmpty(SqStack *S)
判断栈是否为空,语句if (S-top=S-base )判断,若栈不为空,则删除S的栈顶元素,并返回OK;否则返回ERROR。
void CreatGraph (ALGraph *G)
构建图,用邻接表存储,首先定义邻接表指针变量,输入顶点数和弧数,初始化邻接表,将表头向量域置空,输入存在弧的点集合,当输入顶点值超出输入值的范围就会出错,否则依次插入进邻接表,最后输出建立好的邻接表。
2.6 void FindInDegree(ALGrap G, int indegreee[])
求入度操作,设一个存放各顶点入度的数组indegreee[],然后
indegreee[i]=0赋初值,for循环indegreee[]++,存储入度数。
2.7 void TopologicalISort(ALGraph G)
输出拓扑排序函数。其思路是若G无回路,则输出G的顶点的一个拓扑序列并返回OK,否则返回ERROR。首先由于邻接表的存储结构入度为零的顶点即为没有前驱的顶点,我们可
您可能关注的文档
最近下载
- 2025年浙江机电职业技术学院单招职业适应性测试题库完整答案.docx VIP
- 2018年版《广东省安装工程定额说明及计算规则》C.4 电气设备安装工程(上).pdf
- 医疗器械质量记录管理制度.docx
- 规范《GB11586-1989-巴拿马运河导缆孔》.pdf
- 2025年党支部书记学习教育专题党课中央八项规定专题党课讲稿(严守中央八项规定精神,争做新时代合格党员;从中央八项规定精神看党员干部的责任与担当).docx VIP
- 2025年浙江机电职业技术学院单招职业适应性测试题库有答案.docx VIP
- 公开课必备大班绘本数学《一寸虫》.pptx VIP
- 某生产基地工程厂房施工组织设计方案.doc
- 《医疗器械产品技术要求编写指导原则》新旧对照表.pdf
- 20道浙商证券有限责任公司合规专员岗位常见面试问题含HR常问问题考察点及参考回答.docx VIP
文档评论(0)