济南大学信息科学与工程学院数据结构课件 第八章(2).ppt

济南大学信息科学与工程学院数据结构课件 第八章(2).ppt

  1. 1、本文档共108页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
用邻接矩阵表示的图的类定义 template class T, class E class Graphmtx : public GraphT, E { friend istream operator ( istream in, GraphmtxT, E G); //输入 friend ostream operator (ostream out, GraphmtxT, E G); //输出 private: T *VerticesList; //顶点表 E **Edge; //邻接矩阵 int getVertexPos (T vertex) { //给出顶点vertex在图中的位置 for (int i = 0; i numVertices; i++) if (VerticesList[i] == Vertex) return i; return -1; }; public: Graphmtx (int sz = DefaultVertices); //构造函数 ~Graphmtx () //析构函数 { delete [ ]VerticesList; delete [ ]Edge; } T getValue (int i) { //取顶点 i 的值, i 不合理返回0 return i = 0 i = numVertices ? VerticesList[i] : NULL; } E getWeight (int v1, int v2) { //取边(v1,v2)上权值 return v1 != -1 v2 != -1 ? Edge[v1][v2] : 0; } int getFirstNeighbor (int v); //取顶点 v 的第一个邻接顶点 int getNextNeighbor (int v, int w); //取 v 的邻接顶点 w 的下一邻接顶点 bool insertVertex (const T vertex); //插入顶点vertex bool insertEdge (int v1, int v2, E cost); //插入边(v1, v2),权值为cost bool removeVertex (int v); //删去顶点 v 和所有与它相关联的边 bool removeEdge (int v1, int v2); //在图中删去边(v1,v2) }; template class T, class E GraphmtxT, E::Graphmtx (int sz) { //构造函数 maxVertices = sz; numVertices = 0; numEdges = 0; int i, j; VerticesList = new T[maxVertices]; //创建顶点表 Edge = (int **) new int *[maxVertices]; for (i = 0; i maxVertices; i++) Edge[i] = new int[maxVertices]; //邻接矩阵 for (i = 0; i maxVertices; i++) //矩阵初始化 for (j = 0; j maxVertices; j++) Edge[i][j] = (i == j) ? 0 : maxWeight; }; template class T, class E int GraphmtxT, E::getFirstNeighbor (int v) { //给出顶点位置为v的第一个邻接顶点的位置, //如果找不到, 则函数返回-1 if (v != -1) { for (int col = 0; col numVertices; col++) if (Edge[v][col] Edge[v][col] maxWeight) return col; } return -1; }; template class T, class E int GraphmtxT, E:

文档评论(0)

ormition + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档