数据结构拓扑排序实验报告.docxVIP

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

拓扑排序

[基本要求]用邻接表建立一个有向图的存储结构。利用拓扑排序算法输出该图的拓扑排序序列。

[编程思路]

首先图的创建,采用邻接表建立,逆向插入到单链表中,特殊注意有向是不需要对称插入结点,且要把输入的字符在顶点数组中定位(LocateVex(GraphG,char*name),以便后来的遍历操作,几乎和图的创建一样,图的顶点定义时加入intindegree,关键在于indegree的计算,而最好的就是在创建的时候就算出入度,(没有采用书上的indegree。数组的方法,那样会增加一个indegree算法,而是在创建的时候假如一句计数的代码(G.vertices[j].indegree)++;)最后调用拓扑排序的算法,得出拓扑序列。

[程序代码]

头文件:

#paJinaMAX_VHxTHX_NUMcO

#paJinaSTAO为SIZHcO

#paJinaSTAO为INOxHMHNT10

TOC\o1-5\h\z#paJinaO为 I

#paJinaHxxOx °

#paJinaINHHASIH质H 」

#paJinaOVHxH质OW

#paJinaTxUH 1

#paJinaHAJ贡SH 0

$AdapaJin$S$e$us:

SAdapaJin$InJoTAda:$AdapaJin$S$e$us:

SAdapaJin$SHIamT人da:

/*定义弧的结构*/

/*该边所指向的顶点的位置*/

/*该边所指向的顶点的位置*/

/*指向下一条边的指针*/

/*该弧相关信息的指针*/

JArcNode;

/*定义顶点的结构*/

typedefstructVNode{

intindegree;

chardata[10]; /*顶点信息*/

ArcNode*firstarc; /*指向第一条依附该顶点的弧的指针*/

}VNodezAdjList[MAX_VERTEX_NUM];

/*定义图的结构*/typedefstruct{

AdjListvertices;

/*图的当前顶点数和弧数*//*图的类型标志*/

/*图的当前顶点数和弧数*/

/*图的类型标志*/

intkind;

}Graph;

/*定义栈的结构*/

typedefstruct

(

SEIemType*base;

SEIemType*top;

intstacksize;

}Stack;

/*顶点定位*/

intLocateVex(GraphG,char*name);

/*创建有向图*/

voidCreateGraph(GraphG);

/*拓扑排序*/

StatusTopologicalSort(GraphG);

/*初始化栈*/

StatusInitStack(Stacks);

/*判断空*/

StatusEmptyStack(Stacks);

/*压栈*/

StatusPush(Stacks,inte);

/*出栈*/

StatusPop(Stacks,inte);

实现文件:

includestdio.h

#include,malloc.h,,

#includetuopupaixuhead.h

#includestdlib.h

includestring.h

boolvisited[MAX_VERTEX_NUM];

/***********************************************************

顶点定位,返回位序 *

***********************************************************/intLocateVex(GraphG,char*name)

(

inti;

for(i=l;i=G.vexnum;i++)

if(strcmp(name,G.vertices[i].data)==O) 〃返回数组的位置

returni;

return-1;

}

/***********************************************************

创建有向图 *

**********************************************************/

voidCreateGraph(GraphG)(

ArcNode*p;

charnamel[10],name2[10];

intijk;

printf( 请输入顶点数,按回车键结束:);

scanf(%d”,G?vexnum);

printf( 请输入弧数,按回车键结束:

文档评论(0)

贤阅论文信息咨询 + 关注
官方认证
服务提供商

在线教育信息咨询,在线互联网信息咨询,在线期刊论文指导

认证主体成都贤阅网络信息科技有限公司
IP属地四川
统一社会信用代码/组织机构代码
91510104MA68KRKR65

1亿VIP精品文档

相关文档