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

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 閱讀(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;????????????//節點數
????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| av不卡在线观看| 亚洲电影免费在线 | 老色鬼精品视频在线观看播放| 国产精品永久在线| 亚洲一区二区欧美| 一本久久综合亚洲鲁鲁| 欧美日韩一区二区国产| 一区二区激情| 国产精品99久久久久久久vr| 欧美午夜一区二区| 小辣椒精品导航| 午夜视频在线观看一区| 国产一区白浆| 欧美第十八页| 欧美黄色一区| 中日韩高清电影网| 亚洲性视频网站| 国产一区二区三区黄视频| 另类av一区二区| 欧美福利网址| 欧美黑人多人双交| 亚洲一区二区三区高清| 午夜欧美大尺度福利影院在线看| 激情六月婷婷综合| 亚洲高清免费视频| 欧美午夜欧美| 另类亚洲自拍| 欧美三级在线播放| 久久精品国产综合精品| 久久一日本道色综合久久| 一本色道久久加勒比88综合 | 国产亚洲精品一区二区| 美女脱光内衣内裤视频久久网站| 欧美一区观看| 一本到高清视频免费精品| 亚洲免费在线视频| 亚洲国产精品尤物yw在线观看| 99国产精品私拍| 韩国成人精品a∨在线观看| 欧美国产综合| 国产老肥熟一区二区三区| 老司机午夜精品视频在线观看| 欧美国产1区2区| 欧美在线视频观看| 欧美激情自拍| 欧美va天堂va视频va在线| 国产精品国产三级国产aⅴ入口| 老司机精品视频网站| 国产精品视频成人| 亚洲国产精品一区二区第一页| 国产精品丝袜久久久久久app| 欧美高清hd18日本| 国产午夜精品一区二区三区欧美 | 国产精品乱码人人做人人爱| 男男成人高潮片免费网站| 国产精品美女主播| 亚洲黑丝在线| 久久久欧美精品sm网站| 亚洲欧美国产一区二区三区| 久久精品综合一区| 欧美日韩mp4| 欧美激情自拍| 精品白丝av| 亚洲一二三四久久| 99国产精品一区| 免费成人黄色片| 麻豆国产精品777777在线| 国产精品日韩高清| 99热精品在线观看| 一本色道久久综合亚洲精品婷婷| 久久综合图片| 欧美88av| 亚洲欧洲日产国产网站| 老牛嫩草一区二区三区日本| 久久久精彩视频| 国产乱码精品一区二区三| 亚洲午夜精品一区二区| 中文高清一区| 欧美日韩亚洲在线| 亚洲美女少妇无套啪啪呻吟| 亚洲免费成人| 欧美大胆a视频| 亚洲人成在线观看一区二区| 亚洲精品中文字| 欧美韩日视频| 亚洲精品一二| 亚洲免费网址| 国产欧美一区二区三区视频| 性18欧美另类| 久久免费国产精品| 国产在线观看精品一区二区三区| 亚洲欧美中文日韩在线| 小嫩嫩精品导航| 国产三区二区一区久久| 久久精品亚洲乱码伦伦中文 | 久久久精品免费视频| 久久婷婷国产麻豆91天堂| 国产一区二区三区高清在线观看| 久久av免费一区| 蜜臀a∨国产成人精品| 国产一区二区三区在线观看视频 | 亚洲欧美日韩成人高清在线一区| 欧美区亚洲区| 国产精品99久久久久久人| 久久av最新网址| 精品成人一区二区三区| 老妇喷水一区二区三区| 亚洲清纯自拍| 午夜日韩视频| 亚洲电影在线观看| 欧美日韩国产123| 亚洲欧美日韩人成在线播放| 久久综合五月| 一本一本a久久| 国产精品视频自拍| 狂野欧美一区| 99精品福利视频| 久久色在线播放| 99精品欧美一区二区蜜桃免费| 欧美私人网站| 老司机免费视频一区二区| 午夜精品区一区二区三| 国内外成人在线| 毛片av中文字幕一区二区| 在线亚洲欧美专区二区| 免费亚洲网站| 亚洲伊人网站| 亚洲国语精品自产拍在线观看| 国产精品久久久久一区二区三区| 久久精品国产亚洲一区二区三区 | 亚洲精品国产拍免费91在线| 欧美亚洲三级| 一区二区毛片| 亚洲高清二区| 国产欧美在线看| 麻豆国产va免费精品高清在线| 最新高清无码专区| 欧美一二三区在线观看| 日韩天天综合| 在线观看av不卡| 国产欧美精品| 国产精品成人免费| 欧美激情黄色片| 久久久噜噜噜久久久| 亚洲资源av| 在线性视频日韩欧美| 亚洲国产婷婷香蕉久久久久久99 | 最新国产の精品合集bt伙计| 国产亚洲亚洲| 国产精品久久| 欧美人成在线| 久久久中精品2020中文| 亚洲一区在线免费观看| 最近看过的日韩成人| 欧美bbbxxxxx| 老鸭窝亚洲一区二区三区| 久久国产精品久久久久久久久久 | 亚洲第一区在线观看| 欧美三级网页| 欧美激情一二区| 美女爽到呻吟久久久久| 欧美在线国产精品| 亚洲欧美日韩精品在线| 亚洲制服少妇| 亚洲午夜伦理| 亚洲一区国产精品| 亚洲免费视频成人| 久久综合给合| 美国十次成人| 欧美成人午夜激情视频| 欧美福利网址| 亚洲国产综合在线| 91久久中文| 日韩一级在线| 亚洲综合视频一区| 久久成人亚洲| 老牛嫩草一区二区三区日本| 欧美成人资源网| 欧美日韩国产在线播放| 欧美视频日韩| 国产欧美日韩中文字幕在线| 国产主播精品| 亚洲国产影院| 亚洲午夜电影在线观看| 午夜精品久久久久久久99樱桃| 欧美一区二区啪啪| 老司机久久99久久精品播放免费 | 亚洲美女av黄| 亚洲一二三区精品| 欧美一区二区| 欧美成人精品福利| 亚洲免费黄色|