无向图数据结构报告.docx
《无向图数据结构报告.docx》由会员分享,可在线阅读,更多相关《无向图数据结构报告.docx(16页珍藏版)》请在冰豆网上搜索。
无向图数据结构报告
工程造价最小问题
一、问题描述
如果以无向网表示n个城市之间的交通网络建设规划,顶点表示城市,边上的权表示该线路的造价,试设计一个方案,使这个交通网的总造价最小。
二、基本要求
1.了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;
2.初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法
和技能;
3.提高综合运用所学的理论知识和方法独立分析和解决问题的能力;
4.训练用系统的观点和软件开发一般规范进行软件开发,培养软件工作者所具备的科学工作方法和作风。
5.要求完成以下功能
(1)输出顶点信息:
将各地地名输出。
(2)输出边的信息:
将各地间每两个位置(若两个地点之间有直接路径)的距
离输出。
(3)修改:
修改两个地点(若两个地点之间有直接路径)间的工程造价,并重新输出每两个地点(若两个地点之间有直接路径)间的工程造价。
(4)求最最小的工程造价:
输出给定两点之间的最小造价的及途径的地点或输出任意一点与其它各点的最短路径。
(6)删除:
删除任意一条边。
(7)插入:
插入任意一条边。
6.实现要点:
a)对图的创建采用邻接矩阵的存储结构,而且对图的操作设计成了模板类。
为了便于处理,对于图中的每一个顶点和每一条边都设置了初值。
b)为了便于访问,用户可以先输出所有的地点和距离。
c)用户可以随意修改两点之间好的距离。
d)用户可以增加及删除边。
e)当用户操作错误时,系统会出现出错提示。
三、数据结构的设计
1.抽象数据类型图的定义如下:
ADTGraph{
数据对象V:
V是具有相同特性数据元素的集合,称为顶点集。
数据关系R:
R={VR}
VR={(v,w)|v,w∈V,(v,w)表示v和w之间存在路径}
基本操作P:
CreatGraph(&G,V,VR)
初始条件:
V是图的顶点集,VR是图中边的集合。
操作结果:
按定义(V,VR)构造图G。
DestroyGraph(&G)
初始条件:
图G已存在。
操作结果:
销毁图。
LocateVex(G,u)
初始条件:
图G存在,u和G中顶点具有相同特征。
操作结果:
若G中存在顶点u,则返回该顶点在图中“位置”;否则返回
其它信息。
GetVex(G,v)
初始条件:
图G存在,v是G中某个顶点。
操作结果:
返回v的信息。
InsertVex(&G,v)
初始条件:
图G存在,v和G中顶点具有相同特征。
操作结果:
在图G中增添新顶点v。
DeleteVex(&G,v)
初始条件:
图G存在,v和G中顶点具有相同特征。
操作结果:
删除G中顶点v及其相关的边。
InsertArc(&G,v,w)
初始条件:
图G存在,v和w是G中两个顶点。
操作结果:
在G中增添弧,若G是无向的,则还增添对称弧。
DeleteArc(&G,v,w)
初始条件:
图G存在,v和w是G中两个顶点。
操作结果:
在G中删除弧,若G是无向的,则还删除对称弧。
}ADTGraph
2.各函数名
typedefstruct//图中顶点表示点,存放点名称
voidMenu()//输出菜单
voidPutOutVex(MGraph*G)//输出每个顶点的信息
voidPutOutArc(MGraph*G)//输出每条边的信息
voidDijkstra(MGraph*G)//迪杰斯特拉算法求最短路径
voidDeleteVex(MGraph*G)//删除某个顶点
voidDeleteArc(MGraph*G)//删除某条边
voidInsertArc(MGraph*G)//插入某条边
voidmain()//主函数
3.主程序
voidmain()
{
初始化;
while(“命令”!
=“退出”)
{
Switch语句
接受命令(输入选择项序号);
处理命令;
}
}
4.本程序运用函数的调用,只有两个模块,它们的调用关系为:
主程序模块
带权无向图模块
四、程序流程图
五、源程序
#include
#include
#include
#include
#include
#include
#defineMAX10000
#defineMAXLEN8
#defineADJTYPEint
typedefstruct
{
charname[30];
intnum;
}VEXTYPE;
typedefstruct
{
VEXTYPEvexs[MAXLEN];
ADJTYPEarcs[MAXLEN][MAXLEN];
intvexnum,arcnum;
}MGraph;
MGraphb;
MGraphInitGraph()
{
inti,j;
MGraphG;
G.vexnum=6;
G.arcnum=7;
for(i=0;iG.vexs[i].num=i;
strcpy(G.vexs[0].name,"北京");
strcpy(G.vexs[1].name,"重庆");
strcpy(G.vexs[2].name,"广州");
strcpy(G.vexs[3].name,"长沙");
strcpy(G.vexs[4].name,"上海");
strcpy(G.vexs[5].name,"哈尔滨");
for(i=0;ifor(j=0;jG.arcs[i][j]=MAX;
G.arcs[0][5]=100;
G.arcs[0][2]=10;
G.arcs[0][4]=30;
G.arcs[4][5]=60;
G.arcs[4][3]=20;
G.arcs[3][5]=10;
G.arcs[1][2]=5;
for(i=0;ifor(j=0;jG.arcs[j][i]=G.arcs[i][j];
returnG;
}
voidMenu()
{cout<<"需要输出各地点的信息请按0\n";
cout<<"需要各地间工程造价的信息输出请按1\n";
cout<<"需要修改请按2\n";
cout<<"需要求出最小的工程造价请按3\n";
cout<<"需要删除某个地点请按4\n";
cout<<"需要删除某条路径请按5\n";
cout<<"需要插入某条路径请按6\n";
cout<<"需要退出请按7\n";
}
voidPutOutVex(MGraph*G)
{
intv;
for(v=0;vvexnum;v++)
cout<vexs[v].num<vexs[v].name<}
voidPutOutArc(MGraph*G)
{
for(inti=0;ivexnum;i++)
for(intj=0;jvexnum;j++)
if(G->arcs[i][j]{cout<<"从"<vexs[i].name<<"到"<vexs[j].name<arcs[i][j]<}
}
voidChange(MGraph*G)
{intv0,v1,length;
cout<<"change\n";
cin>>v0;
cin>>v1;
cout<<"length:
";
cin>>length;
G->arcs[v0][v1]=G->arcs[v1][v0]=length;
}
voidDijkstra(MGraph*G)
{
intv,w,i,min,t=0,x,v0,v1;
intfinal[20],D[20],p[20][20];
cout<<"请输入出发点:
\n";
cin>>v0;
if(v0<0||v0>G->vexnum)
{
cout<<"此点地点不存在!
请重新输入顶点编号:
";
cin>>v0;
}
cout<<"请输入目的地:
\n";
cin>>v1;
if(v1<0||v1>G->vexnum)
{
cout<<"此点地点不存在!
请重新输入地点编号:
";
cin>>v1;
}
for(v=0;vvexnum;++v)
{
final[v]=0;
D[v]=G->arcs[v0][v];
for(w=0;wvexnum;++w)
p[v][w]=0;
if(D[v]{
p[v][v0]=1;p[v][v]=1;
}
}
D[v0]=0;final[v0]=1;
for(i=1;ivexnum;++i)
{
min=MAX;
for(w=0;wvexnum;++w)
if(!
final[w])
if(D[w]final[v]=1;
for(w=0;wvexnum;++w)
if(!
final[w]&&(min+G->arcs[v][w]{
D[w]=min+G->arcs[v][w];
for(x=0;xvexnum;++x)
p[w][x]=p[v][x];
p[w][w]=1;
}
}
cout<<"从"<vexs[v0].name<<"到"<vexs[v1].name<<"的最小工程造价为:
"<cout<<"路径为:
";
for(intj=0;jvexnum;++j)
{
if(p[v1][j]==1)
cout<vexs[j].name<}
}
voidDeleteVex(MGraph*G)//删除某个顶点
{
introw,col;
intv0;
cout<<"请输入要删除的地点";
cin>>v0;
for(inti=v0;ivexnum;i++)
G->vexs[i]=G->vexs[i+1];
G->vexnum--;
for(row=0;rowvexnum;row++)
{
for(col=v0;colvexnum;col++)
G->arcs[row][col]=G->arcs[row][col+1];
}
for(col=0;colvexnum;col++)
{
for(row=v0;rowvexnum;row++)
G->arcs[col][row]=G->arcs[col][row+1];
}
}
voidDeleteArc(MGraph*G)
{
intv0,v1;
cout<<"请输入两地点:
\n";
cin>>v0>>v1;
G->arcs[v0][v1]=MAX;
G->arcs[v1][v0]=MAX;
}
voidInsertArc(MGraph*G)
{
intv0,v1,l=0;
cout<<"请输入两地点:
\n";
cin>>v0>>v1;
cout<<"请输入工程造价:
\n";
cin>>l;
G->arcs[v0][v1]=l;
G->arcs[v1][v0]=l;
}
voidmain()
{inta;
b=InitGraph();
Menu();
cin>>a;
while(a!
=7)
{
switch(a)
{
case0:
PutOutVex(&b);Menu();break;
case1:
PutOutArc(&b);Menu();break;
case2:
Change(&b);Menu();break;
case3:
Dijkstra(&b);Menu();break;
case4:
DeleteVex(&b);Menu();break;
case5:
DeleteArc(&b);Menu();break;
case6:
InsertArc(&b);Menu();break;
case7:
exit
(1);break;
default:
break;
}
cin>>a;
}
}
六、用户使用手册
1.开始界面
2.输出各地点信息
3.输出各地点间工程造价的信息
5.修改
6.求工程造价最小
7.删除某个地点
8.删除某条路径
9.插入某条路径
10.退出
按7并敲击回车以后系统会自动关闭。
七、心得体会
课程设计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程。
通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,将结论用于实践,从而提高自己的实际动手能力和独立思考的能力。
在设计的过程中当然遇到了问题,可以说得是困难重重,毕竟这是不可避免的,同时在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固。
当指导老师提到用动态数组和链接表来解决这一问题时,我却一头雾水,才发现自己的知识面太窄。
由于编程水平有限,其中迪杰斯特拉算法的C++程序是参考网上的资料,还有顶点的插入设计中没有体现。
我想在以后的学习中,要更注重实践这一环节。
数据结构课程设计报告
设计人:
朱格非0909080627
院系:
信息科学与工程学院
专业班级:
通信工程0801
指导老师:
林立新
完成时间:
2010年6月2日