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

eryar

PipeCAD - Plant Piping Design Software.
PlantAssistant - Translate AVEVA RVM/SP3D VUE to glTF, STEP, etc.
posts - 606, 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; }

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美福利视频在线| 欧美高清不卡在线| 一区二区三区在线免费观看| 国产精品激情电影| 国产乱码精品一区二区三区五月婷 | 欧美在线首页| 久久久久九九九| 麻豆av一区二区三区| 欧美激情91| 国产精品视频yy9299一区| 国产日韩欧美亚洲| 在线精品视频免费观看| 亚洲人成人一区二区三区| aaa亚洲精品一二三区| 亚洲欧美国产高清| 欧美sm极限捆绑bd| 中文久久乱码一区二区| 性色av一区二区怡红| 玖玖综合伊人| 99视频精品| 久久精品盗摄| 欧美日韩亚洲一区二区三区在线| 一本到高清视频免费精品| 亚洲精品乱码久久久久久黑人| 欧美国产日韩a欧美在线观看| 亚洲精品日日夜夜| 久久精品视频播放| 国产精品久久97| 亚洲欧洲日产国产综合网| 亚洲欧美日韩国产综合| 欧美xx视频| 午夜在线精品| 国产精品va| 亚洲精选91| 美女国产一区| 性欧美办公室18xxxxhd| 欧美日韩在线三区| 亚洲国产精品一区二区尤物区 | 久久av二区| 国产精品久久久| 99视频一区二区| 亚洲国产成人精品久久| 久久美女性网| 国产色爱av资源综合区| 亚洲自拍偷拍福利| 日韩午夜一区| 欧美日韩国产片| 最新国产成人在线观看| 久久综合久久久久88| 亚洲免费影视| 国产精品亚洲视频| 午夜在线视频一区二区区别| 中文精品99久久国产香蕉| 欧美日韩亚洲高清一区二区| 日韩亚洲国产精品| 亚洲黄网站在线观看| 久久躁日日躁aaaaxxxx| 影音先锋一区| 欧美电影在线播放| 欧美不卡三区| 一区二区三区日韩精品| 亚洲卡通欧美制服中文| 欧美国产一区二区| 99在线观看免费视频精品观看| 亚洲激情电影在线| 欧美啪啪成人vr| 亚洲一区二区三区四区五区午夜| 日韩视频在线观看免费| 欧美日韩一级片在线观看| 亚洲天堂av在线免费| 宅男精品视频| 国产亚洲欧美日韩在线一区| 久久精品综合网| 久久一区二区精品| 99riav久久精品riav| 一区二区三区免费网站| 国产视频一区二区在线观看 | 亚洲精品在线电影| 欧美人与禽猛交乱配视频| 国产精品亚洲片夜色在线| 一区二区三区久久| 99精品热视频| 国产精品捆绑调教| 亚洲一区二区三区在线看| 一区二区三区日韩欧美精品| 欧美精品一区二区三区高清aⅴ| 黄色成人小视频| 免费在线观看一区二区| 美女视频黄a大片欧美| 日韩一级视频免费观看在线| 亚洲婷婷国产精品电影人久久 | 国产欧美日韩在线观看| 麻豆91精品| 欧美午夜电影完整版| 久久久久久69| 欧美日韩国产综合视频在线观看| 欧美一区二区三区播放老司机 | 久久都是精品| 最新亚洲激情| 午夜一区二区三区在线观看| 亚洲国产精品一区| 亚洲专区在线| 99精品免费视频| 欧美在线欧美在线| 亚洲午夜在线视频| 久久一日本道色综合久久| 亚洲免费在线视频| 欧美成人午夜激情| 久久久久久久久久久久久9999| 免费美女久久99| 久久米奇亚洲| 国产欧美不卡| 亚洲一区二区不卡免费| 亚洲精品一区二区在线| 久久精品女人天堂| 欧美一区二区三区四区在线观看地址 | 亚洲精品综合精品自拍| 国色天香一区二区| 亚洲午夜精品视频| 一本色道久久加勒比88综合| 久久亚洲二区| 玖玖精品视频| 国内精品久久久久影院薰衣草| 亚洲视频一区二区免费在线观看| 亚洲精品一区二区三区樱花| 久久亚洲综合| 欧美电影资源| 亚洲人成啪啪网站| 久久精品一区二区| 久久久久久久欧美精品| 国产精品日韩在线播放| 99视频精品| 在线视频精品| 欧美偷拍另类| 一本色道久久综合亚洲精品按摩| 99精品国产热久久91蜜凸| 欧美福利视频网站| 亚洲大片av| 在线播放日韩| 久久综合一区二区三区| 久久一区中文字幕| 亚洲高清不卡av| 欧美高清视频www夜色资源网| 亚洲国产精品999| 在线亚洲一区二区| 国产精品播放| 欧美在线观看你懂的| 久久综合一区二区| 亚洲人成在线观看| 欧美三级不卡| 亚洲男女自偷自拍| 久久资源av| 在线视频亚洲欧美| 国产麻豆91精品| 久久久久久999| 亚洲精品欧洲精品| 午夜精品久久久99热福利| 国产精品亚洲激情| 久久天堂国产精品| 亚洲日本一区二区| 欧美一区二区三区免费观看| 曰韩精品一区二区| 欧美婷婷在线| 久久综合狠狠| 亚洲私人影院| 欧美黄色一区| 午夜综合激情| 亚洲茄子视频| 国产自产精品| 欧美视频一区二区三区| 久久精品免费播放| 一级成人国产| 欧美激情一区在线观看| 欧美一区二区三区的| 亚洲区免费影片| 国产日韩精品一区观看 | 久久久99免费视频| 亚洲精品在线电影| 久久天堂成人| 亚洲欧美清纯在线制服| 91久久久国产精品| 国产亚洲欧美一区二区| 欧美日韩国产精品自在自线| 欧美一级精品大片| 一本到高清视频免费精品| 久久永久免费| 香蕉乱码成人久久天堂爱免费 | 亚洲午夜91| 亚洲激情六月丁香| 国产在线成人| 国产精品入口夜色视频大尺度 | 一本久久综合亚洲鲁鲁| 欧美成人精品激情在线观看| 欧美顶级艳妇交换群宴| 亚洲大胆视频| 久久久精品五月天| 欧美亚洲综合在线| 亚洲一区二区三区中文字幕 | 亚洲精品社区| 亚洲二区三区四区|