青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

eryar

PipeCAD - Plant Piping Design Software.
RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
posts - 603, comments - 590, trackbacks - 0, articles - 0

圖的鄰接表實現

Adjacency List of the Graph

eryar@163.com

一、圖的鄰接表

  鄰接表(Adjacency List)是圖的一種鏈式存儲結構。在鄰接表中,對圖中每個頂點建立一個單鏈表,第i個單鏈表中的結點表示依附于頂點Vi的邊,對有向圖是以頂點Vi為尾的弧。如下圖所示的圖用鄰接表表示如下:

image   image

根據上圖來定義用鄰接表表示圖的數據結構。當用鄰接表來表示圖時,圖是由頂點序列組成的,在每個頂點中,記錄下與該頂點相連的頂點在頂點序列中的位置。相關的數據結構如下所示:

   1:  struct SVertexNode
   2:  {
   3:      string        data;
   4:      vector<int> vecLoc;
   5:  };
   6:   
   7:  typedef struct SEdge
   8:  {
   9:      int iInitialNode;
  10:   
  11:      int iTerminalNode;
  12:   
  13:  }Edge;
  14:   
  15:  typedef struct Graph
  16:  {
  17:      int iVertexNum;
  18:      int iEdgeNum;
  19:      vector<SVertexNode> vecVertex;
  20:  }Graph;
 
二、C++實現

 

.csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff; /*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em; } .csharpcode .lnum { color: #606060; }

用C++實現上圖所示的圖,代碼如下:

   1:  //------------------------------------------------------------------------------
   2:  //    Copyright (c) 2012 eryar All Rights Reserved.
   3:  //
   4:  //        File    : Main.cpp
   5:  //        Author  : eryar@163.com
   6:  //        Date    : 2012-8-25 17:11
   7:  //        Version : 0.1v
   8:  //
   9:  //    Description : Use Adjacency List data structure to store Digraph.
  10:  //
  11:  //==============================================================================
  12:   
  13:  #include <vector>
  14:  #include <string>
  15:  #include <iostream>
  16:  using namespace std;
  17:   
  18:  struct SVertexNode
  19:  {
  20:      string        data;
  21:      vector<int> vecLoc;
  22:  };
  23:   
  24:  typedef struct SEdge
  25:  {
  26:      int iInitialNode;
  27:   
  28:      int iTerminalNode;
  29:   
  30:  }Edge;
  31:   
  32:  typedef struct Graph
  33:  {
  34:      int iVertexNum;
  35:      int iEdgeNum;
  36:      vector<SVertexNode> vecVertex;
  37:  }Graph;
  38:   
  39:  ///////////////////////////////////////////////////////////////////////////////
  40:  // Functions of Graph
  41:  void    Initialize(Graph& g, int v);
  42:  Edge    MakeEdge(int v, int w);
  43:  void    InsertEdge(Graph& g, const Edge& e);
  44:  void    ShowGraph(const Graph& g);
  45:   
  46:  ///////////////////////////////////////////////////////////////////////////////
  47:  // Main function.
  48:   
  49:  int main(int agrc, char* argv[])
  50:  {
  51:      Graph   aGraph;
  52:   
  53:      // Initialize the graph.
  54:      Initialize(aGraph, 4);
  55:   
  56:      // Insert some edges to make graph.
  57:      InsertEdge(aGraph, MakeEdge(0, 1));
  58:      InsertEdge(aGraph, MakeEdge(0, 2));
  59:      InsertEdge(aGraph, MakeEdge(2, 3));
  60:      InsertEdge(aGraph, MakeEdge(3, 0));
  61:   
  62:      // Show the graph.
  63:      ShowGraph(aGraph);
  64:   
  65:      return 0;
  66:  }
  67:   
  68:  ///////////////////////////////////////////////////////////////////////////////
  69:   
  70:  /**
  71:  * brief    Initialize the graph.
  72:  *
  73:  *       v: vertex number of the graph.
  74:  */
  75:  void Initialize( Graph& g, int v )
  76:  {
  77:      char    szData[6];
  78:      SVertexNode node;
  79:   
  80:      g.iVertexNum    = v;
  81:      g.iEdgeNum      = 0;
  82:   
  83:      for (int i = 0; i < v; i++)
  84:      {
  85:          sprintf(szData, "V%d", i+1);
  86:          node.data   = szData;
  87:          g.vecVertex.push_back(node);
  88:      }
  89:  }
  90:   
  91:  /**
  92:  * brief    Make an edge by initial node and terminal node.
  93:  */
  94:  Edge MakeEdge( int v, int w )
  95:  {
  96:      Edge    e;
  97:   
  98:      e.iInitialNode  = v;
  99:      e.iTerminalNode = w;
 100:   
 101:      return e;
 102:  }
 103:   
 104:  /**
 105:  * brief    Insert an edge to the graph.
 106:  */
 107:  void InsertEdge( Graph& g, const Edge& e )
 108:  {
 109:      g.vecVertex.at(e.iInitialNode).vecLoc.push_back(e.iTerminalNode);
 110:   
 111:      // If the graph is Undigraph, need do something here...
 112:      //g.vecVertex.at(e.iTerminalNode).vecLoc.push_back(e.iInitialNode);
 113:   
 114:      g.iEdgeNum++;
 115:  }
 116:   
 117:  /**
 118:  * brief    Show the graph.
 119:  */
 120:  void ShowGraph( const Graph& g )
 121:  {
 122:      for (int i = 0; i < g.iVertexNum; i++)
 123:      {
 124:          cout<<"Node "<<i<<"("<<g.vecVertex.at(i).data<<")";
 125:   
 126:          for (int j = 0; j < g.vecVertex.at(i).vecLoc.size(); j++)
 127:          {
 128:              cout<<"->"<<g.vecVertex.at(i).vecLoc.at(j);
 129:          }
 130:   
 131:          cout<<endl;
 132:      }
 133:  }
 
三、輸出結果
   1:  Node 0(V1)->1->2
   2:  Node 1(V2)
   3:  Node 2(V3)->3
   4:  Node 3(V4)->0
   5:  Press any key to continue
.csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff; /*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em; } .csharpcode .lnum { color: #606060; }
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            中文高清一区| 久久精品视频va| 欧美亚洲免费在线| 亚洲一区二区三区色| 在线亚洲自拍| 亚洲精品一二| 在线亚洲观看| 亚洲一级在线| 久久精品在线播放| 欧美激情一区| 亚洲色图自拍| 久久精品亚洲热| 另类图片国产| 欧美日韩一区不卡| 国产喷白浆一区二区三区| 一区免费视频| 在线一区二区三区四区五区| 欧美亚洲一区二区在线观看| 老司机亚洲精品| 亚洲高清一区二区三区| av成人激情| 欧美伊人久久大香线蕉综合69| 亚洲一级特黄| 久久黄金**| 亚洲精品乱码久久久久久| 日韩一二三区视频| 久久精品免费观看| 欧美激情中文字幕在线| 国产一区在线看| 亚洲国产精品毛片| 亚洲欧美怡红院| 亚洲国产精品成人va在线观看| 亚洲午夜久久久久久久久电影院| 亚洲永久免费观看| 欧美精品一区二区三区视频| 好看的日韩av电影| 性色一区二区三区| 亚洲乱码视频| 欧美国产日韩xxxxx| 狠狠色香婷婷久久亚洲精品| 亚洲一区在线观看视频| 亚洲国产一区二区三区青草影视 | 亚洲免费久久| 香蕉久久夜色精品| 亚洲毛片在线观看| 裸体一区二区三区| 久久精品99无色码中文字幕| 性欧美在线看片a免费观看| 免费精品99久久国产综合精品| 亚洲在线网站| 国产麻豆日韩| 亚洲尤物在线| 夜夜嗨av一区二区三区中文字幕| 女主播福利一区| 在线观看av不卡| 久久精品国产99| 亚洲人成网站777色婷婷| 久久免费一区| 国产午夜亚洲精品不卡| 日韩亚洲欧美成人| 久久国产欧美| 日韩视频在线观看| 久久久欧美精品| 国产亚洲欧美一区二区| 欧美一区二区成人| 亚洲影视综合| 国产欧美视频一区二区三区| 欧美一区二区三区视频在线| 香蕉成人伊视频在线观看| 国产日韩欧美夫妻视频在线观看| 欧美影院在线播放| 欧美一区二区精美| 尤物99国产成人精品视频| 韩国三级电影一区二区| 国产精品一区一区三区| 欧美尤物巨大精品爽| 亚洲欧美日本国产有色| 国内一区二区三区| 女女同性女同一区二区三区91| 久久视频国产精品免费视频在线| 精品91免费| 亚洲大片精品永久免费| 欧美日韩亚洲视频| 一区二区三区国产在线| 亚洲素人在线| 国内精品久久久久影院色 | 欧美激情国产高清| 日韩天堂在线视频| 日韩视频免费观看高清完整版| 欧美日韩一本到| 香蕉乱码成人久久天堂爱免费 | 美女成人午夜| 午夜精品久久久久影视 | 日韩亚洲一区二区| 亚洲一区二区伦理| 久久久久久国产精品mv| 欧美视频一区二区三区四区| 亚洲日本成人网| 中文在线一区| …久久精品99久久香蕉国产| 亚洲精品一区二区网址| 国产精品亚洲第一区在线暖暖韩国| 久久久精品国产一区二区三区| 欧美成人黄色小视频| 亚洲欧美日韩一区在线| 久久综合色婷婷| 香蕉久久一区二区不卡无毒影院| 久久最新视频| 久久精品国产久精国产爱| 久热re这里精品视频在线6| 欧美一区二区女人| 欧美日本精品| 亚洲大片免费看| 狠狠爱综合网| 亚洲自拍偷拍色片视频| av成人老司机| 欧美成人第一页| 免费不卡欧美自拍视频| 国产日韩精品一区二区| 99国产精品自拍| 亚洲精品中文字幕在线| 久久www成人_看片免费不卡| 亚洲欧美一区在线| 欧美国产日韩一区二区| 国产精品久久精品日日| 亚洲日韩中文字幕在线播放| 在线观看国产成人av片| 午夜精品久久一牛影视| 午夜国产精品视频免费体验区| 久久青青草综合| 久久野战av| 国产精品青草久久| 亚洲国产成人精品女人久久久| 国产欧美综合在线| 欧美在线观看你懂的| 久久久国产精品一区| 国产精品久久久久秋霞鲁丝 | 久久午夜电影网| 久久综合伊人77777蜜臀| 国内精品视频在线播放| 久久99伊人| 老司机午夜精品视频在线观看| 国产欧美日韩综合| 午夜精彩国产免费不卡不顿大片| 亚洲天堂激情| 欧美午夜www高清视频| 亚洲精品国产精品乱码不99| 亚洲免费高清视频| 麻豆国产va免费精品高清在线| 久久久夜色精品亚洲| 国产亚洲福利社区一区| 欧美一级大片在线观看| 久久只有精品| 亚洲国产精品v| 久久夜色精品国产噜噜av| 老司机aⅴ在线精品导航| 亚洲三级免费| 欧美日韩视频在线一区二区观看视频 | 亚洲承认在线| 欧美电影在线观看| 亚洲免费成人| 香蕉久久夜色精品| 亚洲高清网站| 欧美丝袜第一区| 久久riav二区三区| 亚洲精品三级| 久久精品最新地址| 亚洲精品一二三区| 国产精品大全| 久久天天狠狠| 中日韩美女免费视频网址在线观看 | 国产一区二区黄色| 欧美成人精精品一区二区频| 91久久久久| 欧美午夜激情小视频| 性色av一区二区三区| 亚洲国产精品成人综合| 性色av一区二区三区红粉影视| 在线成人www免费观看视频| 欧美视频官网| 你懂的网址国产 欧美| 亚洲免费网址| 亚洲国产一区二区三区青草影视| 久久国产精品第一页| 日韩视频免费看| 一区二区三区在线视频免费观看| 欧美日韩国产色综合一二三四| 久久精品国产亚洲aⅴ| 夜夜爽av福利精品导航| 亚洲成色www久久网站| 久久国产黑丝| 香蕉国产精品偷在线观看不卡| 亚洲毛片在线免费观看| 在线观看日韩av电影| 国产欧美一区二区三区在线看蜜臀 | 国产在线不卡视频| 欧美日韩亚洲在线| 欧美jizz19性欧美| 久久久中精品2020中文| 午夜精品久久久久久99热|