C++图的遍历算法.docVIP

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

#includeiostream.h #define UNVISITED 0 #define VISITED 1 class AdjMatrixUndirGraph { public: int vexNum, edgeNum; // 顶点个数和边数 int **Matrix; // 邻接矩阵 char *elems; // 顶点数据 bool *tag; AdjMatrixUndirGraph(char es[], int vertexNum); int FirstAdjVex(int v) ; // 返回顶点v的第一个邻接点 int NextAdjVex(int v1, int v2);// 返回顶点v1的相对于v2的下一个邻接点 void Display(); void BFS(int v); void DFS(int v); }; AdjMatrixUndirGraph::AdjMatrixUndirGraph(char es[], int vertexNum) { vexNum = vertexNum; edgeNum = 0; elems = new char[vexNum]; int u, v; for(v = 0; v vexNum; v++) { elems[v] = es[v]; } tag = new bool[vexNum]; // 生成标志数组 for(v = 0; v vexNum; v++) { // 初始化标志数组 tag[v] = UNVISITED; } Matrix = (int **)new int *[vexNum];// 生成邻接矩阵 for (v = 0; v vexNum; v++) { // 生成邻接矩阵的行 Matrix[v] = new int[vexNum]; } for (u = 0; u vexNum; u++) { for (v = 0; v vexNum; v++) { // 为邻接矩阵元素赋值 Matrix[u][v] = 0; } } } int AdjMatrixUndirGraph::FirstAdjVex(int v) // 操作结果:返回顶点v的第1个邻接点 { if (v 0 || v = vexNum) { coutv不合法!; return -1; } for (int cur = 0; cur vexNum; cur++) { // 查找邻接点 if (Matrix[v][cur] != 0) return cur; } return -1; // 返回-1表示无邻接点 } int AdjMatrixUndirGraph::NextAdjVex(int v1, int v2) // 操作结果:返回顶点v1的相对于v2的下1个邻接点 { if (v1 0 || v1 = vexNum) { coutv1不合法!; return -1; } if (v2 0 || v2 = vexNum) { coutv1不合法!; return -1; } if (v1 == v2) { coutv1不能等于v2!; return -1; } for (int cur = v2 + 1; cur vexNum; cur++) { // 查找邻接点 if (Matrix[v1][cur] != 0) return cur; } return -1; // 返回-1表示无邻接点 } void AdjMatrixUndirGraph::Display() { int i,j; for(i=0;ivexNum;i++) { for(j=0;jvexNum;j++) coutMatrix[i][j] ; coutendl; } } void AdjMatrixUndirGraph::BFS(int v) { tag[v]=VISITED; // 作访问标志 coutelems[v] ; // 顶点v的数据元素 char queue[50]; // 定义队列 int front=0,rear=0; queue[rear++]=v; // v入队 while(front!=rear) { // 队列q非空, 进行循环 int u, w; // 临时顶点 u=queue[front]; front++; // 出队 for (w = F

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档