数据结构习题集(李冬梅 第2版)C语言版源程序习题源代码习题集-算法6-3_第1页
数据结构习题集(李冬梅 第2版)C语言版源程序习题源代码习题集-算法6-3_第2页
数据结构习题集(李冬梅 第2版)C语言版源程序习题源代码习题集-算法6-3_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、邻接矩阵存储带权无向图 #include using namespace std;定义最大顶点数 define MVNum 128 定义状态类型#define Status int函数结果状态代码/definedefine#define#define#defineOK 1ERROR 0 INFEASIBLE 0EXISTED 2Maxlnt 0 x7fffffff定义图的结构体类型typedef struct int vexs MVNum + 1 ;/顶点集因为顶点存储序号范围为1MVNumint arcs (MVNum + 1 MVNum + 1 ;/邻接矩阵int vexnum, arcn

2、um; /图当前的顶点数和边数)AMGraph;bool SMVNum + 1;int DMVNum + 1;int PathMVNum + 1;采用邻接矩阵表示法,创立无向图graphStatus createUDN(AMGraph Sgraph, int vexnum, int arcnum) graph, vexnutn = vexnurn; 初始化图的总顶点数graph, arcnum = arcnum;/初始化图的总边数if (graph.vexnum MVNum) return ERROR; /顶点数超过最大允许范围,返回错误代码。(注意数组下标从0开始) for (int i =

3、 0; i = graph.vexnum; i+) 依次输入顶点信息graph.vexsi = i;)for (int i 0; i - graph.vexnum; i + +) 初始化所有边的权值为0,表示边不存在for (int j = 0; j = graph.vexnum; j+) graph.arcsij = 0;)int vex one, vex two, weight;一条边依附的两个顶点 vex_one 和 vex_tw。for (int i = 0; i graph. arcnum; i+) 循环输入 arcnum 条边的信息cin vex_one vex_two weigh

4、t;graph.arcs vex_one vex_two = weight; 表权值为 1,表示边存在 graph.arcsvex_twovex_one = weight;return OK; /创立成功,返回成功代码。/定义打印无向图函数void printUDN(AMGraph graph)(for (int i = 0; i = graph.vexnum; i + + ) /在第一行打印顶点信息cout graph.vexsi ”cout endl;for (int i = 1; i = graph.vexnum; i+) /输出边的信息(每行第一个数字为顶点)(注意。号顶点不输出)co

5、ut graph.vexs i u/输出该行对应的顶点for (int j = 1; j = graph.vexnum; j+) 输出该行顶点对应所有边信息cout graph.arcsij ) cout endl;输出结束)用Dijkstra算法求图G中距离顶点vO的最短路径长度最大的一个顶点mint ShortestPathMAX(AMGraph G, int vO)( int n = G.vexnum;for (int v 1; v - n; v+) Sv - false;S初始为空集Dv = G.arcsvOv;if (Dv - 0) Dv Maxint;if (Dv Maxint)

6、Pathv = vO; else Pathv = -1;/end forSv0 = true;DvO - 0;int ShortestPathMAX(AMGraph G, int vO)( int n = G.vexnum;for (int v 1; v - n; v+) Sv - false;S初始为空集Dv = G.arcsvOv;if (Dv - 0) Dv Maxint;if (Dv Maxint) Pathv = vO; else Pathv = -1;/end forSv0 = true;DvO - 0;n为G中顶点的个数将vO到各个终点的最短路径长度初始化为弧上的权值如果vO和v

7、之间有弧,那么将v的前驱置为vO如果vO和v之间无弧,那么将v的前驱置为-1/将vO力口入S/源点到源点的距离为0/*初始化结束,开始主循环.每次求得vO到某个顶点v的最短路径,将v加到S集for (int i = 1; i n; i+) /对其余n-l个顶点,依次进行计算int min - Maxlnt, v;for (int w - 1; w - n; w+ + ) /选择一条当前的最短路径,终点为vif (!Sw & Dw min) v = w;min = Dw;)S v = true;for (int w - 1; w - n; w+) if (IS w & (Dv + G.arcs(

8、v w D(w ) /更新从v。出发到集合V-S上所有顶点的最短路径长度 Dw = Dv + G.arcs v w ;/更新 DwPathw = v;/更改w的前驱为v/ end if/ end for/end for/*最短路径求解完毕,设距离顶点vO的最短路径长度最大的一个顶点为m*/int Max - Dl;int m = 1;for (int i = 2; i = n; i+)if (Max Di)m = i;return m;/返回顶点下标int main() int n, m, w;cout ”请输入顶点的数量n和边的数量m (空格分隔,下同):b;cin n m;/输入n和m的值AMGraph G;cout ”请依次输入m条边所依附的两端顶点以及边权重:n”; createUDN(G, n, m);打印图的信息printUDN(G);int v;cout 请输入开始顶点编号:bn;cin v;cout ShortestPathM

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论