图的遍历和生成树求解实现 课程设计报告.docx
《图的遍历和生成树求解实现 课程设计报告.docx》由会员分享,可在线阅读,更多相关《图的遍历和生成树求解实现 课程设计报告.docx(21页珍藏版)》请在冰豆网上搜索。
图的遍历和生成树求解实现课程设计报告
中北大学
数据结构
课程设计说明书
学生姓名:
郭燕文
学号:
1021011720
学院:
软件学院
专业:
软件工程
题目:
图的遍历和生成树求解实现
成绩
指导教师
尹四清、薛海丽
2011年12月19日
1设计目的:
《数据结构》课程主要介绍最常用的数据结构,阐明各种数据结构内在的逻辑关系,讨论其在计算机中的存储表示,以及在其上进行各种运算时的实现算法,并对算法的效率进行简单的分析和讨论。
进行数据结构课程设计要达到以下目的:
⏹了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;
⏹初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能;
⏹提高综合运用所学的理论知识和方法独立分析和解决问题的能力;
训练用系统的观点和软件开发一般规范进行软件开发,培养软件工作者所应具备的科学的工作方法和作风。
2设计内容和要求
设计内容:
(1)采用合适的存储结构来创建图,并实现图的遍历;
(2)计算图的最小生成树,求联通分量
设计要求:
(1)先任意创建一个图;
(2) 图的DFS,BFS的递归和非递归算法的实现
(3) 最小生成树(两个算法)的实现,求连通分量的实现
(4) 要求用邻接矩阵、邻接表、十字链表多种结构存储实现
3.本设计所采用的数据结构:
本程序是采用邻接矩阵、邻接表、十字链表等多种结构存储来实现对图的存储。
对图的遍历分别采用了广度优先遍历和深度优先遍历。
4.1详细设计思想
这次课程设计我们主要是应用以前学习的数据结构与面向对象程序设计知识,结合起来才完成了这个程序。
因为图是一种较线形表和树更为复杂的数据结构。
在线形表中,数据元素之间仅有线性关系,每个元素只有一个直接前驱和一个直接后继,并且在图形结构中,节点之间的关系可以是任意的,图中任意两个数据元素之间都可能相关。
因此,本程序是采用邻接矩阵、邻接表、十字链表等多种结构存储来实现对图的存储。
采用邻接矩阵即为数组表示法,邻接表和十字链表都是图的一种链式存储结构。
对图的遍历分别采用了广度优先遍历和深度优先遍历。
4.3核心代码
#include
#include
usingnamespacestd;
#defineint_max10000
#defineinf9999
#definemax20
//…………………………………………邻接矩阵定义……………………
typedefstructArcCell22
{
intadj;
char*info;
}ArcCell,AdjMatrix[20][20];
typedefstruct
{charvexs[20];
AdjMatrixarcs;
intvexnum,arcnum;//有向图的当前顶点数和弧数
}MGraph_L;
//^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
intlocalvex(MGraph_LG,charv)//返回V的位置
{inti=0;
while(G.vexs[i]!
=v)
{++i;
}
returni;}
intcreatMGraph_L(MGraph_L&G)//创建图用邻接矩阵表示
{charv1,v2;
inti,j,w;
cout<<"…………创建无向图…………"<(46)不包括"<cin>>G.vexnum>>G.arcnum;
for(i=0;i!
=G.vexnum;++i)
{cout<<"输入顶点"<
cin>>G.vexs[i];}
for(i=0;i!
=G.vexnum;++i)
for(j=0;j!
=G.vexnum;++j)
{G.arcs[i][j].adj=int_max;
G.arcs[i][j].info=NULL;
}
for(intk=0;k!
=G.arcnum;++k)
{cout<<"输入一条边依附的顶点和权:
(ab3)不包括"<cin>>v1>>v2>>w;//输入一条边依附的两点及权值
i=localvex(G,v1);//确定顶点V1和V2在图中的位置
j=localvex(G,v2);
G.arcs[i][j].adj=w;
G.arcs[j][i].adj=w;
}
cout<<"图G邻接矩阵创建成功!
"<returnG.vexnum;
}
voidljjzprint(MGraph_LG)
{inti,j;
for(i=0;i!
=G.vexnum;++i)
{
for(j=0;j!
=G.vexnum;++j)
cout<cout<}
}
intvisited[max];//访问标记
intwe;
typedefstructarcnode//弧结点
{intadjvex;//该弧指向的顶点的位置
structarcnode*nextarc;//弧尾相同的下一条弧
char*info;//该弧信息
}arcnode;
typedefstructvnode//邻接链表顶点头接点
{chardata;//结点信息
arcnode*firstarc;//指向第一条依附该结点的弧的指针
}vnode,adjlist;
typedefstruct//图的定义
{adjlistvertices[max];
intvexnum,arcnum;
intkind;
}algraph;
//…………………………………………队列定义……………………
typedefstructqnode
{intdata;
structqnode*next;
}qnode,*queueptr;
typedefstruct
{queueptrfront;
queueptrrear;
}linkqueue;
//………………………………………………………………………
typedefstructacr
{intpre;//弧的一结点
intbak;//弧另一结点
intweight;//弧的权
}edg;
intcreatadj(algraph&gra,MGraph_LG)//用邻接表存储图
{inti=0,j=0;
arcnode*arc,*tem,*p;
for(i=0;i!
=G.vexnum;++i)
{gra.vertices[i].data=G.vexs[i];
gra.vertices[i].firstarc=NULL;
}
for(i=0;i!
=G.vexnum;++i)
{for(j=0;j!
=G.vexnum;++j)
{if(gra.vertices[i].firstarc==NULL)
{if(G.arcs[i][j].adj!
=int_max&&j!
=G.vexnum)
{arc=(arcnode*)malloc(sizeof(arcnode));
arc->adjvex=j;
gra.vertices[i].firstarc=arc;
arc->nextarc=NULL;
p=arc;
++j;
while(G.arcs[i][j].adj!
=int_max&&j!
=G.vexnum)
{tem=(arcnode*)malloc(sizeof(arcnode));
tem->adjvex=j;
gra.vertices[i].firstarc=tem;
tem->nextarc=arc;
arc=tem;
++j;
}
--j;
}
}
else
{if(G.arcs[i][j].adj!
=int_max&&j!
=G.vexnum)
{
arc=(arcnode*)malloc(sizeof(arcnode));
arc->adjvex=j;
p->nextarc=arc;
arc->nextarc=NULL;
p=arc;
}
}
}
}
gra.vexnum=G.vexnum;
gra.arcnum=G.arcnum;
/*for(i=0;i!
=gra.vexnum;++i)
{arcnode*p;
cout<
p=gra.vertices[i].firstarc;
while(p!
=NULL)
{cout<adjvex;
p=p->nextarc;
}
cout<}*/
cout<<"图G邻接表创建成功!
"<return1;
}
voidadjprint(algraphgra)
{inti;
for(i=0;i!
=gra.vexnum;++i)
{arcnode*p;
cout<
p=gra.vertices[i].firstarc;
while(p!
=NULL)
{cout<adjvex;
p=p->nextarc;
}
cout<}
}
intfirstadjvex(algraphgra,vnodev)//返回依附顶点V的第一个点
//即以V为尾的第一个结点
{if(v.firstarc!
=NULL)
returnv.firstarc->adjvex;
}
intnextadjvex(algraphgra,vnodev,intw)//返回依附顶点V的相对于W的下一个顶点
{arcnode*p;
p=v.firstarc;
while(p!
=NULL&&p->adjvex!
=w)
{p=p->nextarc;
}
if(p->adjvex==w&&p->nextarc!
=NULL)
{p=p->nextarc;
returnp->adjvex;
}
if(p->adjvex==w&&p->nextarc==NULL)
return-10;
}
intinitqueue(linkqueue&q)//初始化队列
{q.rear=(queueptr)malloc(sizeof(qnode));
q.front=q.rear;
if(!
q.front)
return0;
q.front->next=NULL;
return1;
}
intenqueue(linkqueue&q,inte)//入队
{queueptrp;
p=(queueptr)malloc(sizeof(qnode));
if(!
p)
return0;
p->data=e;
p->next=NULL;
q.rear->next=p;
q.rear=p;
return1;
}
intdequeue(linkqueue&q,int&e)//