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

tommy

It's hard to tell the world we live in is either a reality or a dream
posts - 52, comments - 17, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

鄰接表 SparseMultiGRAPH

Posted on 2006-04-01 11:23 Tommy Liang 閱讀(853) 評論(1)  編輯 收藏 引用 所屬分類: 讀書筆記《C++圖算法》
SparseMultiGRAPH.h
#pragma?once
struct?Edge????????//
{
????
int?v,w;
????Edge(?
int?v?=?-1,?int?w?=?-1)?:?v(v),?w(w)?{?}
}
;

class?SparseMultiGRAPH??
{
private:
????
int?Vcnt;????????????//節點數
????int?Ecnt;????????????//邊數
????bool?digraph;????????//是否有向圖
????struct?node????????????//節點
????{
????????
int?v;????????????//節點值
????????node*?next;????????//鄰接節點
????????node(int?x,node*?t)?{?v?=?x;?next?=?t;?}
????}
;
????typedef?node
*?link;????????
????vector
<link>?adj;????????//鄰接表
public:
????
????SparseMultiGRAPH(
int?V,?bool?digraph?=?false);
????
~SparseMultiGRAPH();
????
int?V()?const;????????????//取節點數
????int?E()?const;????????????//取邊數
????bool?directed()?const;????????//取是否有向圖
????void?insert(Edge?e);????????//插入邊
????void?remove(Edge?e);????????????//移除邊
????bool?edge(int?v,int?w)?const;????????//判斷兩點間是否存在邊

????
class?adjIterator;????????????????//iterator
????friend?class?adjIterator;??????
}
;

class?SparseMultiGRAPH::adjIterator
{
????
const?SparseMultiGRAPH?&G;
????
int?v;
????link?t;
public:
????adjIterator(
const?SparseMultiGRAPH?&G,int?v);
????
int?beg();
????
int?nxt();
????
bool?end();
}
;

SparseMultiGRAPH.cpp

#include?"SparseMultiGRAPH.h"

SparseMultiGRAPH::SparseMultiGRAPH(
int?V,?bool?digraph)?:?
????adj(V),?Vcnt(V),?Ecnt(
0),?digraph(digraph)
{
????adj.assign(V,
0);
}

SparseMultiGRAPH::
~SparseMultiGRAPH()
{
????
for(int?i=0;i?<?Vcnt;?i++)
????
{
????????delete?adj[i];
????}

}

int?SparseMultiGRAPH::V()?const?
{?
????
return?Vcnt;??
}

int?SparseMultiGRAPH::E()?const?
{?
????
return?Ecnt;??
}

bool?SparseMultiGRAPH::directed()?const?
{?
????
return?digraph;?
}

void?SparseMultiGRAPH::insert(Edge?e)
{
????
int?v?=?e.v;
????
int?w?=?e.w;
????adj[v]?
=?new?node(w,?adj[v]);
????
if?(?!digraph)?
????????adj[w]?
=?new?node(v,adj[w]);
????Ecnt?
++;
}

void?SparseMultiGRAPH::remove(Edge?e)
{
??
int?v?=?e.v;
??
int?w?=?e.w;
??adj.erase(adj.begin()?
+?v,?adj.begin()?+?v?+?1);
??
int?i?=?v?<?w???w-1?:?w;
??adj.erase(adj.begin()?
+?i,?adj.begin()?+?i?+?1);
}

bool?SparseMultiGRAPH::edge(int?v,int?w)?const
{?
????node?
*?p?=?adj[v];
????
while(?p?!=?NULL)
????
{
????????
if(p->v?==?w)
????????????
return?true;
????????p?
=?p->next;
????}

????
return?false;
}


SparseMultiGRAPH::adjIterator::adjIterator(
const?SparseMultiGRAPH?&G,int?v)?:?G(G),?v(v)
{
????t?
=?0;
}

int?SparseMultiGRAPH::adjIterator::beg()
{
????t?
=?G.adj[v];?
????
return?t???t->v?:?-1;
}

int?SparseMultiGRAPH::adjIterator::nxt()
{
????
if?(t)?t?=?t->next;?
????
return?t???t->v?:?-1;
}

bool?SparseMultiGRAPH::adjIterator::end()
{
????
return?t?==?0;
}

用法:

#include?<tchar.h>
#include?
<windows.h>
#include?
<iostream>

#include?
"KTimer.h"
#include?
"SparseMultiGRAPH.h"

int?main(int?argc,?char*?argv[])
{????
????KTimer?timer;

????unsigned?cpuspeed10?
=?timer.GetCPUSpeed();

????timer.Start();
????
????SparseMultiGRAPH?g(
5);
????Edge?e1(
0,1);
????Edge?e2(
1,2);
????Edge?e3(
2,3);
????Edge?e4(
0,2);
????Edge?e5(
1,3);

????Edge?e6(
1,4);
????Edge?e7(
2,4);
????Edge?e8(
3,4);


????g.insert(e1);
????g.insert(e2);
????g.insert(e3);
????g.insert(e4);
????g.insert(e5);
????g.insert(e6);
????g.insert(e7);
????g.insert(e8);
????
????cout?
<<?"0到2存在邊?"?<<?g.edge(0,2)?<<?endl;
????cout?
<<?"0到3存在邊?"?<<?g.edge(0,3)?<<?endl;

????SparseMultiGRAPH::adjIterator?gitor(g,
1);
????
for(int?i=gitor.beg();?!gitor.end();?i?=?gitor.nxt())
????????cout?
<<?i?<<?endl;

????unsigned?time?
=?timer.Stop();

????TCHAR?mess[
128];
????wsprintf(mess,_T(
"耗時:%d?ns"),?time?*?10000?/?cpuspeed10);
????cout?
<<?mess?<<?endl;

????
return?0;
}

Feedback

# re: 鄰接表 SparseMultiGRAPH  回復  更多評論   

2011-05-16 12:28 by windward
remove好像不太對吧,我們只是刪一條邊,你的刪了很多呀
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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久久中文| 中文日韩在线| 国产视频欧美| 免费久久99精品国产自| 亚洲人成网站影音先锋播放| 午夜在线a亚洲v天堂网2018| 狠狠色狠狠色综合日日tαg| 99国产精品自拍| 蘑菇福利视频一区播放| 国产精品中文字幕在线观看| 麻豆精品精华液| 久久精品国产亚洲一区二区| 国产精品视频久久久| 久久亚洲风情| 亚洲欧美久久久| 亚洲破处大片| 蜜乳av另类精品一区二区| 狠狠色丁香久久婷婷综合_中| 亚洲免费在线观看视频| 狼人天天伊人久久| 国产视频一区欧美| 亚洲欧美日韩综合国产aⅴ| 亚洲国产免费看| 久久久精品日韩| 亚洲欧美在线看| 亚洲欧洲日产国产综合网| 国产资源精品在线观看| 欧美日韩视频免费播放| 亚洲美女一区| 亚洲福利免费| 麻豆成人在线观看| 一本久道久久综合狠狠爱| 影音先锋久久| 国产精品视频内| 国产精品国产精品| 亚洲欧美精品| 亚洲午夜在线观看| 99国内精品久久| 欧美在线观看视频一区二区| 亚洲天堂免费观看| 日韩午夜电影在线观看| 91久久在线观看| 亚洲成人资源| 亚洲黄色三级| 亚洲美女中文字幕| 亚洲国产天堂久久综合网| 亚洲大胆av| 亚洲福利视频一区| 91久久精品国产91性色tv| 亚洲大胆人体视频| 亚洲国产成人精品视频| 亚洲国产成人一区| 亚洲精选一区| 在线中文字幕日韩| 亚洲视频中文| 欧美一级久久久久久久大片| 久久精品一区二区三区不卡| 久久免费午夜影院| 久久五月激情| 91久久中文| 在线视频欧美一区| 欧美一区二区三区成人| 久久蜜桃资源一区二区老牛| 欧美成人精品不卡视频在线观看| 亚洲婷婷综合久久一本伊一区| 欧美大片免费看| 亚洲激情六月丁香| 亚洲最新视频在线| 欧美一区二区三区另类| 久久青青草原一区二区| 欧美日本亚洲| 国产香蕉久久精品综合网| 欧美日韩精品一区二区三区四区 | 免费试看一区| 亚洲黄色三级| 中文亚洲欧美| 久久久久免费视频| 欧美日韩高清一区| 国产美女精品视频| 91久久久久久久久久久久久| 亚洲综合国产激情另类一区| 欧美一区二区三区啪啪| 午夜精品久久久久久久99黑人| 日韩视频一区| 日韩午夜在线播放| 蜜桃久久av| 国产精品国内视频| 亚洲福利视频免费观看| 精品av久久久久电影| 国产亚洲欧美一区在线观看| 免费黄网站欧美| 久久五月婷婷丁香社区| 国产精品一区二区男女羞羞无遮挡 | 合欧美一区二区三区| 亚洲精品久久久久久久久久久久久| 精品成人a区在线观看| 一本色道久久综合亚洲91| 久久亚洲视频| 欧美阿v一级看视频| 亚洲一区二区三区免费视频 | 亚洲乱码国产乱码精品精可以看 | 亚洲中无吗在线| 欧美日韩99| 亚洲日韩第九十九页| 久久久之久亚州精品露出| 久久网站免费| 欧美一进一出视频| 国产精品每日更新| 99这里只有久久精品视频| 美国成人毛片| 欧美一区二区视频免费观看| 久久人人97超碰精品888| 欧美成人高清| 亚洲人成亚洲人成在线观看| 亚洲午夜久久久久久久久电影网| 亚洲一区二区视频| 亚洲裸体视频| 欧美日韩在线不卡| 一区二区三区不卡视频在线观看| 欧美一级视频免费在线观看| 一区二区欧美在线| 欧美午夜美女看片| 亚洲直播在线一区| 一区二区三欧美| 国产精品黄视频| 亚洲第一页中文字幕| 女同一区二区| 麻豆国产va免费精品高清在线| 国产精品v欧美精品v日本精品动漫| 国产视频亚洲精品| 裸体丰满少妇做受久久99精品| 一区二区三区免费看| 国产精品美女久久久免费| 久久精品72免费观看| 久久aⅴ国产紧身牛仔裤| 精品999成人| 最新亚洲一区| 国产精品久久77777| 久久精品国产第一区二区三区| 亚洲第一黄色网| 欧美日韩国产色视频| 亚洲精品欧美专区| 亚洲精品乱码久久久久久久久 | 欧美1区视频| 欧美va亚洲va香蕉在线| 国产亚洲视频在线观看| 久久婷婷久久| 欧美日韩免费观看一区| 亚洲欧美在线磁力| 久久久久久久国产| 国产欧美日韩一区二区三区在线观看| 亚洲高清在线观看一区| 久久久久久综合网天天| 亚洲国产精品毛片| 亚洲视频高清| 一区精品在线播放| 亚洲人成网站在线观看播放| 欧美日韩国产成人| 午夜精品久久久久久久99热浪潮 | 91久久国产自产拍夜夜嗨| 亚洲免费成人av电影| 国产欧美日韩一区二区三区| 蜜臀91精品一区二区三区| 欧美激情精品| 久久精品免费看| 欧美激情无毛| 久久国产福利| 欧美精品免费播放| 销魂美女一区二区三区视频在线| 夜夜精品视频一区二区| 黄色一区二区三区四区| 久久久久久久波多野高潮日日| 亚洲精品网址在线观看| 国模精品一区二区三区色天香| 亚洲免费人成在线视频观看| 西西人体一区二区| 99精品久久久| 久久免费的精品国产v∧| 亚洲视频精选| 欧美jjzz| 久久综合九色欧美综合狠狠| 久久福利影视| 新狼窝色av性久久久久久| 欧美亚洲色图校园春色| 亚洲少妇在线| 久久本道综合色狠狠五月| 一区二区不卡在线视频 午夜欧美不卡在 | 一本色道88久久加勒比精品| 影音先锋亚洲一区| 午夜精品一区二区三区电影天堂| 国产一区自拍视频| 亚洲手机成人高清视频| 日韩亚洲欧美一区二区三区| 久久久www| 久久久久高清| 久久久99国产精品免费| 尤妮丝一区二区裸体视频|