图论——链式前向星

概述

链式前向星是解决图论的一种方法,一开始接触会有点绕,但是真的好用!首先要有个意识,这个方法的出发点是以边为核心建结构体,这个结构体有一个很妙的变量next,是用来存同一起点的上一条边的编号。除了结构体之外,再建一个head数组,head[i]存的是i作为起点的最后一条边的编号。通过next和head的结合,可以巧妙地进行存边、遍历等操作。

结构体

建结构体时应注意,如果题目给了m条边,应该结构体数组应该2*m个空间(因为双向)。

struct Edge {
    int v, w, next;
}e[maxm<<1];

addEdge

注意如果是无向图的话,main函数加边的时候记得加两条边,即双向。

void addEdge(int u, int v, int w) {
    e[cnt].v = v;
    e[cnt].w = w;
    e[cnt].next = head[u];
    head[u] = cnt++;
}

遍历x为起点的边

这里的前提是将head数组初始化为-1。

for(int i = head[x]; i != -1; i = e[i].next)
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值