|
Posted on 2006-04-01 11:23 Tommy Liang 阅读(829) 评论(1) 编辑 收藏 引用 所属分类: 读书笔记《C++图算法》
SparseMultiGRAPH.h #pragma once
struct Edge //边
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
int v,w;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" Edge( int v = -1, int w = -1) : v(v), w(w) { }
};
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
class SparseMultiGRAPH
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
private:
int Vcnt; //节点数
int Ecnt; //边数
bool digraph; //是否有向图
struct node //节点
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
int v; //节点值
node* next; //邻接节点
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" 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; //判断两点间是否存在边
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
class adjIterator; //iterator
friend class adjIterator;
};
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
class SparseMultiGRAPH::adjIterator
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
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"
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
SparseMultiGRAPH::SparseMultiGRAPH(int V, bool digraph) :
adj(V), Vcnt(V), Ecnt(0), digraph(digraph)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
adj.assign(V,0);
}
SparseMultiGRAPH::~SparseMultiGRAPH()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
for(int i=0;i < Vcnt; i++)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
delete adj[i];
}
}
int SparseMultiGRAPH::V() const
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
return Vcnt;
}
int SparseMultiGRAPH::E() const
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
return Ecnt;
}
bool SparseMultiGRAPH::directed() const
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
return digraph;
}
void SparseMultiGRAPH::insert(Edge e)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
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)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
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
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
node * p = adj[v];
while( p != NULL)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
if(p->v == w)
return true;
p = p->next;
}
return false;
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
SparseMultiGRAPH::adjIterator::adjIterator(const SparseMultiGRAPH &G,int v) : G(G), v(v)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
t = 0;
}
int SparseMultiGRAPH::adjIterator::beg()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
t = G.adj[v];
return t ? t->v : -1;
}
int SparseMultiGRAPH::adjIterator::nxt()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
if (t) t = t->next;
return t ? t->v : -1;
}
bool SparseMultiGRAPH::adjIterator::end()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
return t == 0;
}用法:
#include <tchar.h>
#include <windows.h>
#include <iostream>
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
#include "KTimer.h"
#include "SparseMultiGRAPH.h"
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int main(int argc, char* argv[])
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
KTimer timer;
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
unsigned cpuspeed10 = timer.GetCPUSpeed();
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
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);
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
Edge e6(1,4);
Edge e7(2,4);
Edge e8(3,4);
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
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;
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
SparseMultiGRAPH::adjIterator gitor(g,1);
for(int i=gitor.beg(); !gitor.end(); i = gitor.nxt())
cout << i << endl;
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
unsigned time = timer.Stop();
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
TCHAR mess[128];
wsprintf(mess,_T("耗时:%d ns"), time * 10000 / cpuspeed10);
cout << mess << endl;
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
return 0;
}
Feedback
# re: 邻接表 SparseMultiGRAPH 回复 更多评论
2011-05-16 12:28 by
remove好像不太对吧,我们只是删一条边,你的删了很多呀
|