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

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>
            国产精品久久久久久久app| 久久夜色撩人精品| 国产精品萝li| 国产精品国产一区二区| 国产精品剧情在线亚洲| 国产精品一区二区三区成人| 国产午夜精品在线| 影音先锋久久资源网| 亚洲国产婷婷香蕉久久久久久| 亚洲国产精品精华液网站| 日韩亚洲一区二区| 欧美在线免费观看| 欧美xxx成人| 日韩一本二本av| 亚洲在线成人| 蜜臀久久99精品久久久久久9| 欧美日韩精品免费观看视频| 国产视频一区在线观看| 亚洲精品免费在线观看| 欧美一级电影久久| 免费在线看一区| 亚洲午夜激情网页| 久久综合久久综合这里只有精品| 欧美精品日韩精品| 国产综合色产| 亚洲一区二区三区在线视频| 免费不卡中文字幕视频| 一区二区冒白浆视频| 久久一综合视频| 国产精品永久免费| 一区二区三欧美| 欧美国产免费| 香蕉久久夜色精品国产| 久久国产视频网| 香蕉成人啪国产精品视频综合网| 久久综合狠狠| 国产美女精品人人做人人爽| 亚洲欧洲三级电影| 久久九九热免费视频| aⅴ色国产欧美| 久久一区二区三区av| 国产日韩精品入口| 亚洲欧美高清| 99这里只有精品| 欧美xxx成人| 激情综合色丁香一区二区| 亚洲男女毛片无遮挡| 亚洲精品国产精品国自产观看| 一区二区三区免费在线观看| 麻豆九一精品爱看视频在线观看免费| 国产欧美欧洲在线观看| 亚洲午夜一区二区三区| 最新国产拍偷乱拍精品 | 国产欧美精品一区二区色综合| 夜夜夜精品看看| 最近中文字幕日韩精品| 久久夜色精品国产亚洲aⅴ| 精品成人国产| 蜜臀a∨国产成人精品| 欧美一区二区三区免费看| 国产精品一区视频网站| 午夜久久久久久| 亚洲淫性视频| 国产亚洲精品综合一区91| 久久精品国产v日韩v亚洲| 亚洲欧美综合v| 狠狠爱成人网| 欧美国产激情二区三区| 欧美国产在线观看| 99精品国产99久久久久久福利| 亚洲国产成人久久| 欧美久久综合| 亚洲欧美一区二区三区久久| 午夜视频在线观看一区| 激情懂色av一区av二区av| 亚洲高清三级视频| 国产精品亚洲а∨天堂免在线| 欧美怡红院视频一区二区三区| 欧美一级大片在线观看| 亚洲高清在线观看一区| 亚洲精品综合精品自拍| 国产精品红桃| 久久久不卡网国产精品一区| 裸体素人女欧美日韩| 亚洲无线一线二线三线区别av| 亚洲天堂视频在线观看| 狠狠干综合网| 亚洲美女精品成人在线视频| 国产欧美日韩综合| 亚洲黄色免费网站| 国产日韩精品一区二区| 久久九九免费| 国产精品99久久久久久久久| 卡一卡二国产精品| 亚洲伦理在线观看| 牛牛精品成人免费视频| 一区二区三区高清不卡| 亚洲国产一区二区a毛片| 国产精品尤物| 国产精品久久久久毛片软件 | 国内外成人免费视频| 亚洲欧美精品suv| 欧美寡妇偷汉性猛交| 欧美成人国产va精品日本一级| 麻豆av一区二区三区久久| 久久只有精品| 日韩视频精品在线| 欧美影院视频| 欧美劲爆第一页| 国产精品热久久久久夜色精品三区| 欧美大片在线观看| 久久久五月天| 久久伊人亚洲| 欧美激情精品久久久久久| 欧美激情综合亚洲一二区 | 欧美中文日韩| 香蕉久久夜色精品| 久久免费偷拍视频| 美腿丝袜亚洲色图| 亚洲精品偷拍| 欧美在线一级va免费观看| 亚洲欧美日韩成人高清在线一区| 亚洲一区二区在| 午夜精品视频在线观看一区二区| 亚洲精品久久久久久久久久久久久| 亚洲高清在线精品| 亚洲香蕉成视频在线观看| 麻豆精品在线视频| 99re6热在线精品视频播放速度| 午夜精品久久久久久久久| 美日韩精品免费| 国产一区二区成人| 亚洲素人一区二区| 欧美大片免费久久精品三p| 中文网丁香综合网| 欧美va亚洲va国产综合| 国产亚洲欧洲997久久综合| 99国产麻豆精品| 亚洲国产一区二区三区青草影视 | 在线观看日韩专区| 亚洲深夜福利| 亚洲国产日韩欧美在线图片| 欧美一区二区三区在线观看 | 久久都是精品| 国产乱码精品一区二区三| 9久re热视频在线精品| 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲国产欧美日韩精品| 午夜国产一区| 在线午夜精品| 欧美体内she精视频在线观看| 亚洲精品123区| 亚洲精品自在久久| 欧美性猛交99久久久久99按摩| 亚洲精品一线二线三线无人区| 欧美~级网站不卡| 欧美精品日本| 久久精精品视频| 91久久久久久国产精品| 亚洲另类视频| 国产精品尤物| 久久综合九九| 欧美精品成人| 欧美中文日韩| 欧美日韩一区二区三区免费| 亚洲欧美精品在线观看| 欧美一区二区三区在线视频| 亚洲电影免费观看高清| 一本大道久久精品懂色aⅴ| 国产精品狼人久久影院观看方式| 午夜日韩视频| 欧美精品久久久久久久久老牛影院| 亚洲精品影院| 久久久噜噜噜久久中文字免| 亚洲影院色无极综合| 久久久噜噜噜久久久| 久久精品欧洲| 国产精品视频内| 99精品视频免费观看| 日韩亚洲欧美成人一区| 美女任你摸久久| 久久亚洲精品欧美| 在线播放豆国产99亚洲| 久久久久9999亚洲精品| 久久激情五月激情| 国产噜噜噜噜噜久久久久久久久| 亚洲精选一区二区| 亚洲理论在线观看| 欧美日韩精品在线| 一区二区三区精品视频在线观看| 亚洲美女视频网| 欧美午夜精品久久久久免费视 | 亚洲天堂成人在线视频| 亚洲夜间福利| 99re亚洲国产精品| 亚洲欧美精品在线| 黄色成人在线| 欧美精品日韩www.p站| 亚洲欧美日韩另类精品一区二区三区 | 久久久久久久久综合|