(第十二周项目4)利用遍历思想求解图问题
来源:互联网 发布:sjf算法流程图 编辑:程序博客网 时间:2024/06/04 00:40
问题:
/* * Copyright (c)2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:项目4.cpp * 作 者:黄玉娇 * 完成日期:2016年11月17日 * 版 本 号:v1.0 问题描述:假设图G采用邻接表存储,分别设计实现以下要求的算法,要求用区别于示例中的图进行多次测试,通过观察输出值,掌握相关问题的处理方法。 设计一个算法,判断顶点u到v是否有简单路径 输入描述:无 输出描述:若干数据 */头文件及功能函数详见【图算法库】
代码:
#include <stdio.h> #include <malloc.h> #include "graph.h" int visited[MAXV]; //定义存放节点的访问标志的全局数组 void ExistPath(ALGraph *G,int u,int v, bool &has) { int w; ArcNode *p; visited[u]=1; if(u==v) { has=true; return; } p=G->adjlist[u].firstarc; while (p!=NULL) { w=p->adjvex; if (visited[w]==0) ExistPath(G,w,v,has); p=p->nextarc; } } void HasPath(ALGraph *G,int u,int v) { int i; bool flag = false; for (i=0; i<G->n; i++) visited[i]=0; //访问标志数组初始化 ExistPath(G,u,v,flag); printf(" 从 %d 到 %d ", u, v); if(flag) printf("有简单路径\n"); else printf("无简单路径\n"); } int main() { ALGraph *G; int A[5][5]= { {0,0,0,0,0}, {0,0,1,0,0}, {0,0,0,1,1}, {0,0,0,0,0}, {1,0,0,1,0}, }; //请画出对应的有向图 ArrayToList(A[0], 5, G); HasPath(G, 1, 0); HasPath(G, 4, 1); return 0; }
测试图结构及存储 :
运行结果:
0 0
- 第十二周项目4-利用遍历思想求解图问题
- 第十二周项目4利用遍历思想求解图问题
- 第十二周项目4--利用遍历思想求解图问题
- (第十二周项目4)利用遍历思想求解图问题
- 第十二周 项目4 -利用遍历思想求解图问题
- 第十二周项目4----利用遍历思想求解图问题
- 第十二周项目4-利用遍历思想求解图问题
- 第十二周项目4-利用遍历思想求解图问题
- 【第十二周项目4 - 利用遍历思想求解图问题】
- 第十二周项目4-利用遍历思想求解图问题
- 第十二周项目4 利用遍历思想求解图问题
- 第十二周项目4 利用遍历思想求解图问题
- 第十二周项目4-利用遍历思想求解图问题
- 第十二周 项目4 -利用遍历思想求解图问题
- 第十二周项目4-利用遍历思想求解图问题
- 【 第十二周项目4----利用遍历思想求解图问题】
- 第十二周项目4-利用遍历思想求解图问题(2-广度优先遍历)
- 第十二周项目四 利用遍历思想求解图问题
- Mac下配置环境导致终端无法执行.bash_profile命令的解决方法
- fuel架构介绍
- JavaScript Class
- angular url参数获取,修改以及端口获取等
- 安装记录
- (第十二周项目4)利用遍历思想求解图问题
- Spark提交任务到集群
- 揭秘! 张柏芝大秀美腿撩倒小鲜肉, 一天能让所以男人爱上自己
- #Paper Reading# Fast Online EM for Big Topic Modeling
- Android App优化, 要怎么做?
- AIDL初探:夸进程的通信和跨进程的回调机制
- Flume(NG)架构设计要点及配置实践
- react组件自定义写法
- (转)【NOIP模拟题】【线段树】【扫描线】2016.11.17 第三题 矩形 题解