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

首先告訴大家一個好消息,數(shù)據(jù)結(jié)構(gòu)到這里就要結(jié)束了!然后再來一個壞消息,這里是數(shù)據(jù)結(jié)構(gòu)中“最沒有意義”的部分和最難的部分。圖的應(yīng)用恐怕是所有結(jié)構(gòu)中最寬泛的了,但這也注定了在講“數(shù)據(jù)結(jié)構(gòu)的圖”的時候沒什么好講的——關(guān)于圖的最重要的是算法,而且相當?shù)囊徊糠侄际呛軐I(yè)的,一般的人幾乎不會接觸到;相對而言,結(jié)構(gòu)就顯得分量很輕。你可以看到關(guān)于圖中元素的操作很少,遠沒有單鏈表那里列出的一大堆“接口”。——一個結(jié)構(gòu)如果復(fù)雜,那么能確切定義的操作就很有限。

不管怎么說,還是先得把圖存起來。不要看書上列出了好多方法,根本只有一個——鄰接矩陣。如果矩陣是稀疏的,那就可以用十字鏈表來儲存矩陣(見前面的《稀疏矩陣(十字鏈表)》)。如果我們只關(guān)系行的關(guān)系,那么就是鄰接表(出邊表);反之,只關(guān)心列的關(guān)系,就是逆鄰接表(入邊表)。

下面給出兩種儲存方法的實現(xiàn)。

#ifndef Graphmem_H

#define Graphmem_H

 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

#include <vector>

#include <list>

using namespace std;

template <class name, class dist, class mem> class Network;

const int maxV = 20;//最大節(jié)點數(shù)

template <class name, class dist>

class AdjMatrix

{

friend class Network<name, dist, AdjMatrix<name, dist> >;

public:

       AdjMatrix() : vNum(0), eNum(0)

       {

              vertex = new name[maxV]; edge = new dist*[maxV];

             for (int i = 0; i < maxV; i++) edge[i] = new dist[maxV];

       }

       ~AdjMatrix()

       {

             for (int i = 0; i < maxV; i++) delete []edge[i];

              delete []edge; delete []vertex;

       }

       bool insertV(name v)

       {

              if (find(v)) return false;

              vertex[vNum] = v;

             for (int i = 0; i < maxV; i++) edge[vNum][i] = NoEdge;

              vNum++; return true;

       }

       bool insertE(name v1, name v2, dist cost)

       {

              int i, j;

              if (v1 == v2 || !find(v1, i) || !find(v2, j)) return false;

              if (edge[i][j] != NoEdge) return false;

              edge[i][j] = cost; eNum++; return true;

       }

       name& getV(int n) { return vertex[n]; } //沒有越界檢查

       int nextV(int m, int n)//返回m號頂點的第n號頂點后第一個鄰接頂點號,無返回-1

       {

              for (int i = n + 1; i < vNum; i++) if (edge[m][i] != NoEdge) return i;

              return -1;

       }

private:

       int vNum, eNum;

       dist NoEdge, **edge; name *vertex;

       bool find(const name& v)

       {

             for (int i = 0; i < vNum; i++) if (v == vertex[i]) return true;

              return false;

       }

       bool find(const name& v, int& i)

       {

              for (i = 0; i < vNum; i++) if (v == vertex[i]) return true;

              return false;

       }

};

template <class name, class dist>

class LinkedList

{

friend class Network<name, dist, LinkedList<name, dist> >;

public:

       LinkedList() : vNum(0), eNum(0) {}

       ~LinkedList()

       {

             for (int i = 0; i < vNum; i++) delete vertex[i].second;

       }

       bool insertV(name v)

       {

              if (find(v)) return false;

              vertex.push_back(pair<name, list<edge>* >(v, new list<edge>));

              vNum++; return true;

       }

       bool insertE(name v1, name v2, dist cost)

       {

              int i, j;

              if (v1 == v2 || !find(v1, i) || !find(v2, j)) return false;

              for (list<edge>::iterator iter = vertex[i].second->begin();

              iter != vertex[i].second->end(); iter++) if (iter->vID == j) return false;

              vertex[i].second->push_back(edge(j, cost)); eNum++; return true;

       }

       name& getV(int n) { return vertex[n].first; } //沒有越界檢查

       int nextV(int m, int n)//返回m號頂點的第n號頂點后第一個鄰接頂點號,無返回-1

       {

              for (list<edge>::iterator iter = vertex[m].second->begin();

              iter != vertex[m].second->end(); iter++) if (iter->vID > n) return iter->vID;

              return -1;

       }

 

private:

       bool find(const name& v)

       {

             for (int i = 0; i < vNum; i++) if (v == vertex[i].first) return true;

              return false;

       }

       bool find(const name& v, int& i)

       {

              for (i = 0; i < vNum; i++) if (v == vertex[i].first) return true;

              return false;

       }

       struct edge

       {

              edge() {}

              edge(int vID, dist cost) : vID(vID), cost(cost) {}

              int vID;

              dist cost;

       };

       int vNum, eNum;

       vector<pair<name, list<edge>* > > vertex;

};

#endif

這個實現(xiàn)是很簡陋的,但應(yīng)該能滿足后面的講解了。現(xiàn)在這個還什么都不能做,不要急,在下篇將講述圖的DFSBFS

Posted on 2005-12-15 12:58 艾凡赫 閱讀(489) 評論(0)  編輯 收藏 引用 所屬分類: C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩国语| 性感少妇一区| 欧美日韩国产精品一区二区亚洲| 亚洲欧美日韩人成在线播放| 亚洲美洲欧洲综合国产一区| 亚洲国产精品久久久久秋霞影院| 久久天天躁狠狠躁夜夜爽蜜月| 久久爱www.| 欧美激情第一页xxx| 欧美国产一区二区| 91久久综合亚洲鲁鲁五月天| 亚洲精品乱码久久久久久日本蜜臀| 欧美在线亚洲在线| 欧美1区视频| 伊人成人在线| 久久视频在线看| 99精品福利视频| 1000精品久久久久久久久| 免费欧美在线视频| 一本大道av伊人久久综合| 女人天堂亚洲aⅴ在线观看| 亚洲成人在线网站| 亚洲精品一区二区三区不| 亚洲高清不卡在线观看| 久久人91精品久久久久久不卡| 欧美一级视频免费在线观看| 欧美一区二区三区久久精品茉莉花| 亚洲第一色中文字幕| 这里只有精品电影| 久久久噜噜噜久久狠狠50岁| 亚洲精品日韩激情在线电影| 午夜精品福利视频| 欧美三级黄美女| 亚洲激情视频网| 久久亚洲一区| 久久岛国电影| 国产欧美日韩不卡免费| 亚洲无亚洲人成网站77777 | 性欧美大战久久久久久久免费观看 | 欧美一区不卡| 国产精品国产三级欧美二区| 亚洲精品免费一区二区三区| 免费在线亚洲| 欧美r片在线| 亚洲四色影视在线观看| 一本色道精品久久一区二区三区 | 欧美天天视频| 午夜视频在线观看一区二区三区| 一本色道久久综合亚洲精品按摩| 女女同性女同一区二区三区91| 亚洲精品护士| 亚洲视频在线观看| 在线视频欧美日韩精品| 欧美精品免费在线| 一区二区欧美国产| 亚洲在线第一页| 伊人久久综合97精品| 亚洲国产日日夜夜| 欧美三级韩国三级日本三斤| 久久久久国产一区二区三区| 欧美黑人国产人伦爽爽爽| 午夜精品剧场| 欧美国产日韩亚洲一区| 欧美在线视频一区| 欧美激情第三页| 久久视频一区二区| 欧美少妇一区二区| 欧美sm极限捆绑bd| 黑人巨大精品欧美黑白配亚洲| 日韩视频免费看| 日韩亚洲欧美精品| 鲁大师影院一区二区三区| 欧美在线影院| 国产精品美女主播| 亚洲尤物视频在线| 午夜久久久久久| 国产精品国产三级国产| 一区二区毛片| 99精品热视频只有精品10| 欧美成人午夜激情在线| 免费看亚洲片| 在线国产欧美| 久久嫩草精品久久久精品| 久久久久国产精品一区二区| 国产精品一级在线| 久久精品72免费观看| 免费亚洲电影| 亚洲毛片播放| 国产精品青草综合久久久久99| 亚洲电影激情视频网站| 久久免费国产精品| 亚洲国产精品国自产拍av秋霞| 亚洲免费不卡| 国产亚洲欧美另类中文| 久久一区二区视频| 在线亚洲欧美视频| 久久嫩草精品久久久精品| 亚洲国产三级在线| 国产精品色一区二区三区| 久久动漫亚洲| 夜夜嗨一区二区| 欧美成人免费观看| 激情成人中文字幕| 欧美揉bbbbb揉bbbbb| 美日韩精品视频免费看| 亚洲一区二区三区精品视频| 欧美国产综合一区二区| 午夜久久福利| 亚洲一区观看| 亚洲午夜精品久久久久久浪潮 | 国产精品区一区二区三| 美腿丝袜亚洲色图| 久久www免费人成看片高清| 亚洲精品视频在线观看免费| 毛片精品免费在线观看| 久久精品免费观看| 久久午夜激情| 美女爽到呻吟久久久久| 久久精品色图| 久久综合99re88久久爱| 欧美 日韩 国产 一区| 久久综合亚州| 亚洲韩国日本中文字幕| 亚洲欧洲精品一区二区三区波多野1战4| 久久男人av资源网站| 欧美va亚洲va日韩∨a综合色| 136国产福利精品导航网址| 一区二区三区在线观看欧美| 国产在线精品一区二区中文| 在线观看国产精品淫| 亚洲日本欧美| 久久精品女人| 亚洲国产美女| 久久本道综合色狠狠五月| 久久国产一二区| 欧美亚州一区二区三区| 午夜日韩激情| 欧美.日韩.国产.一区.二区| 久久久久久久综合色一本| 一区三区视频| 这里只有精品电影| 美女精品网站| 久久国产欧美精品| 悠悠资源网亚洲青| 欧美大片va欧美在线播放| 久久婷婷久久一区二区三区| 91久久精品一区| 亚洲视频一区| 亚洲国产美女| 一个人看的www久久| 国产主播喷水一区二区| 欧美激情亚洲激情| 国产精品高精视频免费| 久久―日本道色综合久久| 欧美精品九九| 久久久无码精品亚洲日韩按摩| 免费观看一区| 久久久91精品国产一区二区三区 | 亚洲国产午夜| 欧美电影电视剧在线观看| 亚洲精品老司机| 日韩一级精品| 狠狠色狠狠色综合人人| 欧美成人精品影院| 国产精品福利在线观看| 国产精品久久久久久久久免费樱桃 | 欧美在线观看网址综合| 久久尤物电影视频在线观看| 亚洲天堂黄色| 欧美国产日韩一区二区| 女人色偷偷aa久久天堂| 国产午夜精品一区理论片飘花| 亚洲看片一区| 91久久国产自产拍夜夜嗨| 久久精品国产一区二区三区| 亚洲午夜激情在线| 麻豆精品在线视频| 欧美在线视频一区二区| 欧美日韩亚洲国产精品| 亚洲国产精品第一区二区三区| 亚洲国产高清在线| 老牛嫩草一区二区三区日本| 亚洲自拍偷拍网址| 国产精品欧美精品| 亚洲欧美电影在线观看| 久久精品一级爱片| 国产一区二区三区在线观看免费视频 | 亚洲精品国久久99热| 久久九九免费视频| 久久久999精品免费| 国产精品外国| 亚洲欧美日韩国产成人精品影院| 西西裸体人体做爰大胆久久久| 国产精品乱子久久久久| 久久精品人人做人人爽电影蜜月| 欧美77777| 欧美在线播放| 99国内精品久久| 韩国一区二区三区美女美女秀| 久久综合久久88|