一般来讲,图的常用存储结构有邻接矩阵,和邻接表,但我们知道邻接矩阵空间浪费太严重,邻接表不好写,今天来讲一下图的另一只常用的存储结构:前向星和链式前向星,介于上述两种存储结构之间的一种比较均衡的存储结构。
首先我们来说一下图的前向星表示方法:
前向星是一种通过存储边信息的方式来存储图的一种数据结构,他构造简单,读入每条边的信息,将边存放在数组中,把数组中的边按照起点顺序排列,前向星也就构造完成了。方便查询,我们用另外一个数组head(i)来存储起点为vi的第一条边的位置。
存储结构:
int head[MAXN];
struct Node
{
int from;//起点
int to;//终点
int w;//权值
};
Node map[MAXN];
比较函数:
bool cmp(const Node &a,const Node &b)
{
if(a.from==b.from)
{
if(a.to==b.to) return a.w<b.w;
else return a.to<b.to;
}
else return a.from<b.from;
}
读入数据:
cin>>n>>