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

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>
            亚洲图片欧美日产| 亚洲男女自偷自拍| 欧美午夜一区二区三区免费大片| 久久免费视频网站| 久久久国产精品亚洲一区 | 亚洲女同在线| 午夜精品免费视频| 久久久久久精| 麻豆精品视频在线观看| 欧美fxxxxxx另类| 亚洲激情在线| 亚洲国产精品久久久久秋霞不卡| 亚洲人成人77777线观看| 夜夜爽夜夜爽精品视频| 亚洲欧美日韩精品在线| 久久国产主播| 免费高清在线一区| 亚洲乱码国产乱码精品精98午夜| 国产精品99久久久久久白浆小说 | 99国产精品久久久久久久久久| 一区二区三区四区五区视频| 欧美一区二区观看视频| 欧美成人首页| 国产亚洲欧美一区二区| 亚洲日本中文字幕| 欧美诱惑福利视频| 亚洲精品在线观看免费| 久久精品国产亚洲5555| 欧美偷拍另类| 亚洲经典在线| 久久久久亚洲综合| 一二三区精品| 欧美大片免费观看| 国内外成人免费视频| 亚洲手机在线| 亚洲国产1区| 久久精品亚洲精品国产欧美kt∨| 欧美日韩精品一本二本三本| 狠狠色噜噜狠狠色综合久| 亚洲欧美日韩国产另类专区| 欧美激情 亚洲a∨综合| 久久精品av麻豆的观看方式| 欧美午夜精彩| av不卡在线看| 亚洲级视频在线观看免费1级| 欧美专区一区二区三区| 国产精品亚洲视频| 亚洲一区在线看| 亚洲狼人精品一区二区三区| 蜜桃av久久久亚洲精品| 黄色成人在线网站| 久久国产黑丝| 校园激情久久| 国产欧美一区二区色老头| 亚洲与欧洲av电影| 亚洲美女黄色| 欧美四级在线| 亚洲一区二区综合| 日韩一二在线观看| 欧美精品在线免费观看| 亚洲精美视频| 日韩视频不卡| 欧美三级欧美一级| 亚洲图片在线观看| 亚洲天堂av在线免费观看| 国产精品成人一区二区三区夜夜夜| 日韩视频永久免费观看| 亚洲黄页一区| 欧美日本国产在线| 亚洲一级黄色| 亚洲一二三四区| 国产日韩欧美在线播放| 久久精品免费电影| 久久米奇亚洲| 久久这里有精品15一区二区三区| 狠狠干综合网| 欧美黄色网络| 欧美午夜在线| 久久久久国产精品人| 久久嫩草精品久久久精品| 亚洲国产视频a| av成人免费在线| 国产日产欧美一区| 欧美成人午夜激情在线| 欧美日韩国产成人| 欧美一区成人| 久久五月激情| 亚洲另类视频| 亚洲一区日本| 精品av久久707| 91久久精品国产91性色| 欧美性猛交xxxx乱大交蜜桃| 欧美影院在线| 美女视频黄免费的久久| 亚洲天堂成人| 久久夜色精品一区| 亚洲欧美清纯在线制服| 久久阴道视频| 亚洲一区二区在线免费观看视频 | 欧美日本国产精品| 香蕉久久夜色精品| 久久久久久穴| 亚洲综合精品| 欧美1区免费| 欧美一区免费视频| 欧美激情影院| 久久精品一区中文字幕| 欧美日韩国产综合视频在线观看中文| 欧美在线三级| 欧美激情综合亚洲一二区| 久久国产色av| 欧美日韩中文字幕在线| 麻豆精品精华液| 国产精品三级久久久久久电影| 欧美xxx成人| 国产欧美日韩视频| 亚洲精品人人| 亚洲日本中文字幕| 久久中文字幕导航| 欧美一区二区视频在线| 欧美三级日本三级少妇99| 亚洲大胆视频| 在线日韩电影| 久久激情综合| 久久久999精品免费| 国产麻豆成人精品| 亚洲色图综合久久| 一区二区三区 在线观看视频| 免费观看成人鲁鲁鲁鲁鲁视频| 久久综合九色欧美综合狠狠| 国产精品麻豆欧美日韩ww| 亚洲九九爱视频| 中文一区字幕| 欧美揉bbbbb揉bbbbb| 一区二区三区欧美在线观看| 一区二区欧美在线| 欧美图区在线视频| 日韩亚洲一区在线播放| 日韩亚洲欧美一区| 亚洲三级免费观看| 99re热精品| 欧美日韩精品高清| 99精品视频网| 亚洲在线观看视频| 国产精品亚洲综合天堂夜夜| 亚洲一区二区三区在线播放| 欧美一区网站| 狠狠色丁香久久婷婷综合丁香| 午夜精品电影| 美女日韩欧美| 亚洲人线精品午夜| 欧美日韩视频免费播放| 一本久久a久久精品亚洲| 羞羞答答国产精品www一本| 国产欧美日韩综合| 久久深夜福利免费观看| 亚洲欧洲一级| 欧美在线不卡| 亚洲高清不卡一区| 欧美日韩亚洲一区二区三区| 亚洲视频国产视频| 久久久亚洲影院你懂的| 亚洲国产一区二区三区青草影视 | 久久在精品线影院精品国产| 韩国亚洲精品| 欧美激情第六页| 亚洲永久免费av| 美女精品视频一区| 亚洲视频axxx| 极品尤物久久久av免费看| 欧美高清视频一区二区三区在线观看 | 久久国产精品网站| 亚洲电影在线播放| 亚洲欧洲av一区二区| 亚洲国产精品ⅴa在线观看| 欧美日本视频在线| 欧美一区二区三区播放老司机| 欧美国产另类| 午夜精品影院| 亚洲乱码一区二区| 国产一区二区高清| 欧美精品网站| 久久久精品国产免费观看同学| 日韩图片一区| 欧美不卡在线| 久久久久久999| 亚洲一区二区三区影院| 亚洲电影av| 国产一区二区三区四区hd| 欧美日韩午夜精品| 老**午夜毛片一区二区三区| 亚洲欧美经典视频| 99re视频这里只有精品| 美女主播精品视频一二三四| 午夜在线观看免费一区| 亚洲无线视频| 一本色道久久88亚洲综合88| 亚洲高清二区| 伊人久久婷婷色综合98网| 国产午夜精品久久久久久免费视 |