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

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++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

鄰接表 SparseMultiGRAPH

Posted on 2006-04-01 11:23 Tommy Liang 閱讀(852) 評論(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;????????????//節(jié)點(diǎn)數(shù)
????int?Ecnt;????????????//邊數(shù)
????bool?digraph;????????//是否有向圖
????struct?node????????????//節(jié)點(diǎn)
????{
????????
int?v;????????????//節(jié)點(diǎn)值
????????node*?next;????????//鄰接節(jié)點(diǎn)
????????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;????????????//取節(jié)點(diǎn)數(shù)
????int?E()?const;????????????//取邊數(shù)
????bool?directed()?const;????????//取是否有向圖
????void?insert(Edge?e);????????//插入邊
????void?remove(Edge?e);????????????//移除邊
????bool?edge(int?v,int?w)?const;????????//判斷兩點(diǎn)間是否存在邊

????
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(
"耗時(shí):%d?ns"),?time?*?10000?/?cpuspeed10);
????cout?
<<?mess?<<?endl;

????
return?0;
}

Feedback

# re: 鄰接表 SparseMultiGRAPH  回復(fù)  更多評論   

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>
            亚洲欧美日韩成人| 欧美天堂亚洲电影院在线播放| 久久精品视频99| 亚洲一级黄色| 亚洲特级毛片| 99国内精品久久| 亚洲精品永久免费| 99精品欧美一区二区三区| 99精品国产福利在线观看免费| 亚洲人成人99网站| 一区二区三区日韩欧美| 一区二区三区四区国产| 亚洲综合日韩| 久久精品1区| 美女精品一区| 亚洲二区视频| 欧美成人精品h版在线观看| 欧美国产一区二区在线观看| 国产精品免费观看在线| 亚洲国产高清在线观看视频| 欧美激情精品久久久| 亚洲国内自拍| 在线中文字幕不卡| 亚洲伊人第一页| 久久精品国产清高在天天线| 久久久久久久综合色一本| 欧美mv日韩mv国产网站app| 欧美日韩亚洲高清一区二区| 欧美新色视频| 激情欧美亚洲| 99热免费精品| 久久国产视频网站| 亚洲国产精品视频| 亚洲综合视频在线| 蘑菇福利视频一区播放| 国产精品欧美日韩| 狠狠色丁香久久婷婷综合_中| 亚洲精品一区在线观看香蕉| 午夜在线一区| 亚洲国产综合在线看不卡| 亚洲欧美日本日韩| 欧美精品久久99| 国语自产精品视频在线看抢先版结局 | 国产网站欧美日韩免费精品在线观看| 黑人中文字幕一区二区三区| 99精品视频一区二区三区| 久久久久久亚洲综合影院红桃 | 国产精品狠色婷| 在线成人www免费观看视频| 亚洲小说欧美另类婷婷| 蜜桃av一区二区在线观看| 亚洲一级黄色av| 欧美另类综合| 亚洲激情一区| 蜜臀a∨国产成人精品| 亚洲欧美卡通另类91av| 欧美色网一区二区| 亚洲免费av电影| 欧美高清视频在线| 久久精品在线视频| 国产亚洲欧美一区在线观看| 亚洲女同精品视频| 一区二区av在线| 欧美日韩大片| 夜夜嗨av一区二区三区网页| 欧美福利视频| 蜜臀久久久99精品久久久久久 | 国精品一区二区三区| 一区二区激情视频| 欧美激情网友自拍| 久久免费99精品久久久久久| 国产午夜亚洲精品理论片色戒| 亚洲一区二区在线视频| 亚洲精品一二| 欧美日韩国产综合久久| av不卡在线观看| 日韩视频免费在线观看| 欧美黄色免费网站| 妖精成人www高清在线观看| 亚洲精品小视频在线观看| 欧美三级在线播放| 亚洲欧美日韩精品一区二区| 亚洲小视频在线| 国产精品一区二区三区观看| 欧美中文字幕在线观看| 午夜精品婷婷| 国产综合精品| 欧美va亚洲va香蕉在线| 久久伊人一区二区| 亚洲黄网站在线观看| 亚洲国产专区| 国产精品分类| 久久亚洲综合色| 欧美成人综合一区| 亚洲视频在线观看网站| 亚洲欧美日韩视频一区| 国产真实久久| 免费观看成人网| 欧美激情一区二区三区不卡| 一本色道久久综合| 亚洲免费视频成人| 黄色日韩精品| 亚洲激情电影在线| 国产精品久久久久高潮| 欧美一区二区高清在线观看| 久久久久国产精品麻豆ai换脸| 亚洲人成网站777色婷婷| 中文无字幕一区二区三区| 国产一区二区三区四区| 欧美激情第10页| 欧美性色视频在线| 狂野欧美激情性xxxx欧美| 欧美精品一线| 久久精品国产77777蜜臀| 欧美国产日韩亚洲一区| 欧美一区二区视频在线| 男人天堂欧美日韩| 欧美日韩一区二区在线观看视频 | 裸体一区二区| 亚洲午夜女主播在线直播| 欧美怡红院视频一区二区三区| 亚洲精品一区二区三区在线观看 | 国产综合色精品一区二区三区| 久久综合九色九九| 久久综合久久久久88| 亚洲欧美一区二区精品久久久| 久久手机免费观看| 午夜久久黄色| 欧美日韩伦理在线免费| 男男成人高潮片免费网站| 国产精品日韩在线观看| 亚洲精品视频免费在线观看| 亚洲成在人线av| 欧美一区二区高清在线观看| 亚洲视频一二| 欧美精品一区二区三区在线看午夜| 久久香蕉精品| 国内揄拍国内精品久久| 亚洲欧美在线看| 亚洲欧美区自拍先锋| 欧美日韩亚洲网| 亚洲精品影视在线观看| 日韩视频在线观看国产| 欧美黑人在线播放| 亚洲日本电影在线| 日韩视频在线一区二区| 欧美激情精品久久久久久久变态| 欧美电影免费观看大全| 亚洲电影第1页| 美女脱光内衣内裤视频久久网站| 久久亚洲综合色| 亚洲福利视频在线| 免费精品99久久国产综合精品| 玖玖国产精品视频| 在线观看欧美| 欧美精品久久久久久久免费观看 | 国产精品久久久久久久久借妻| 亚洲国产日韩欧美在线99| 亚洲激情一区二区三区| 嫩模写真一区二区三区三州| 亚洲国产91| 亚洲精品一区二区三区四区高清| 欧美激情国产精品| 日韩午夜三级在线| 亚洲免费在线看| 国产精品一区一区| 午夜精品影院| 欧美风情在线观看| 夜夜爽夜夜爽精品视频| 国产精品任我爽爆在线播放 | 一本一本久久a久久精品综合妖精| 欧美另类高清视频在线| 一区二区三区久久| 欧美专区在线播放| 在线观看福利一区| 欧美日韩精品免费观看| 亚洲午夜女主播在线直播| 久久精品亚洲一区| 亚洲高清在线播放| 国产精品qvod| 久久亚洲综合| 亚洲卡通欧美制服中文| 欧美一区日韩一区| 亚洲福利视频网| 国产精品午夜在线观看| 久久男人资源视频| 国产一区二区三区观看| 久久综合一区二区| 玖玖玖国产精品| 亚洲午夜精品国产| 国内一区二区三区| 欧美体内she精视频在线观看| 久久久九九九九| 日韩一级黄色av| 快播亚洲色图| 欧美一区二区黄色| 正在播放日韩| 亚洲福利视频专区| 国产小视频国产精品| 欧美日韩一级片在线观看|