链式前向星是一种常见的储存图的方式(是前向星存图法的优化版本),支持增边和查询,但不支持删边(如果想要删除指定的边建议用邻接矩阵)。

  • 储存方式

  首先定义数组 head[ i ] 来储存从节点 i 出发的第一条边的下标,定义结构体 edge[ i ] 中包含三个元素 nxt, to, val, 分别储存从节点 i 出发的下一条边的下标(nxt),该边的终点(to), 该边的边权(val)。

 struct EDGE {
int nxt, to, val; /* 下一条边的下标, 这条边的终点, 边权 */
};
EDGE edge[maxn]; int head[maxn]; /* head[ i ]储存从节点 i 出发的第一条边的下标 */
  • 添加节点

  定义变量 cnt 表示当前边的编号(初始值为0),具体如代码所示。

 int cnt = ;

 void add ( int st, int ed, int v ) {
edge[ ++cnt ].nxt = head[st];
edge[cnt].to = ed;
edge[cnt].val = v;
head[st] = cnt; /*
edge[ ++cnt ].nxt = head[ed]; * 如果是无向图就加上这个语句
edge[cnt].to = st;
edge[cnt].val = v;
head[ed] = cnt; */ }
  • 节点的遍历

  从数据结构就可以看出来,上代码。

 /* i 是作为原点的节点编号 */
for ( int j = head[i]; j != ; j = edge[j].nxt ) /* <-- 链式前向星遍历的关键 */
printf ( "-->%d || val = %d \n", edge[j].to, edge[j].val );
}
  • 汇总代码
 #include <cstdio>
#include <cstring> using namespace std; const int maxn = ; struct EDGE {
int nxt, to, val; /* 下一条边的下标, 这条边的终点, 边权 */
};
EDGE edge[maxn]; int head[maxn], cnt = ; /* head[ i ]储存从节点 i 出发的第一条边的下标 */ void add ( int st, int ed, int v ) {
edge[ ++cnt ].nxt = head[st];
edge[cnt].to = ed;
edge[cnt].val = v;
head[st] = cnt; /*
edge[ ++cnt ].nxt = head[ed]; * 如果是无向图就加上这个语句
edge[cnt].to = st;
edge[cnt].val = v;
head[ed] = cnt; */ } int main () {
memset ( head, , sizeof head );
int n, m;
scanf ( "%d%d", &m, &n ); /* 共有 m 个节点, n 条边 */
for ( int i = ; i <= n; i ++ ){
int a, b, c;
scanf ( "%d%d%d", &a, &b, &c );
add ( a, b, c );
}
for ( int i = ; i <= m; i ++ ){
printf ( "开始以节点%d为原点\n", i );
for ( int j = head[i]; j != ; j = edge[j].nxt ) /* <-- 链式前向星遍历的关键 */
printf ( "-->%d || val = %d \n", edge[j].to, edge[j].val );
}
return ;
}

【C++学习笔记】 链式前向星的更多相关文章

  1. poj-1459-最大流dinic+链式前向星-isap+bfs+stack

    title: poj-1459-最大流dinic+链式前向星-isap+bfs+stack date: 2018-11-22 20:57:54 tags: acm 刷题 categories: ACM ...

  2. 链式前向星+SPFA

    今天听说vector不开o2是数组时间复杂度常数的1.5倍,瞬间吓傻.然后就问好的图表达方式,然后看到了链式前向星.于是就写了一段链式前向星+SPFA的,和普通的vector+SPFA的对拍了下,速度 ...

  3. 单元最短路径算法模板汇总(Dijkstra, BF,SPFA),附链式前向星模板

    一:dijkstra算法时间复杂度,用优先级队列优化的话,O((M+N)logN)求单源最短路径,要求所有边的权值非负.若图中出现权值为负的边,Dijkstra算法就会失效,求出的最短路径就可能是错的 ...

  4. hdu2647 逆拓扑,链式前向星。

    pid=2647">原文地址 题目分析 题意 老板发工资,可是要保证发的工资数满足每一个人的期望,比方A期望工资大于B,仅仅需比B多1元钱就可以.老板发的最低工资为888元.输出老板最 ...

  5. 图的存储结构:邻接矩阵(邻接表)&链式前向星

    [概念]疏松图&稠密图: 疏松图指,点连接的边不多的图,反之(点连接的边多)则为稠密图. Tips:邻接矩阵与邻接表相比,疏松图多用邻接表,稠密图多用邻接矩阵. 邻接矩阵: 开一个二维数组gr ...

  6. 【模板】链式前向星+spfa

    洛谷传送门--分糖果 博客--链式前向星 团队中一道题,数据很大,只能用链式前向星存储,spfa求单源最短路. 可做模板. #include <cstdio> #include <q ...

  7. zzuli 2131 Can Win dinic+链式前向星(难点:抽象出网络模型+建边)

    2131: Can Win Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 431  Solved: 50 SubmitStatusWeb Board ...

  8. HDU1532 Drainage Ditches SAP+链式前向星

    Drainage Ditches Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  9. zzuli 2130: hipercijevi 链式前向星+BFS+输入输出外挂

    2130: hipercijevi Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 595  Solved: 112 SubmitStatusWeb B ...

随机推荐

  1. 修改apk里面的源码

    1.解压apk文件,获取classes.dex并拷贝到资源根目录(使用zip或其他解压工具即可) 2.使用baksmali工具将classes.dex转为smali文件,在命令行定位到资源根目录并执行 ...

  2. 3 - Selenium元素定位和操作

    3.1定位 <button id="gbqfba" aria-label="Google Search" name="btnK" cl ...

  3. Cucumber 场景大纲 Scenario Outlines

    引用链接:https://github.com/cucumber/cucumber/wiki/Scenario-Outlines script/cucumber --i18n zh-CN | feat ...

  4. Java面向对象的练习。动物乐园

    本次项目是:以面向对象的思想设计动物乐园系统. 动物乐园中有猫,狗,鸭子等成员,还可以增加新成员. 猫和鸭子都有自己的名字,都有自己的腿,但腿的条数不同,猫和鸭子会发出叫声,猫的叫声是:喵喵喵……,鸭 ...

  5. spring-boot 配置jsp

    sring-boot 集成  jsp spring-boot默认使用的页面展示并不是jsp,若想要在项目中使用jsp还需要配置一番. 虽然spring-boot中也默认配置了InternalResou ...

  6. Mongodb简介及基本操作

    一.简介 MongoDB是一款强大.灵活.且易于扩展的通用型数据库 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性 ...

  7. CF1182E Product Oriented Recurrence

    思路: fn = can * f1xn * f2yn * f3zn, 首先dp计算指数部分an = an-1 + an-2 + an-3 + 2 * n - 6, 而an-1 = an-2 + an- ...

  8. php 03

    php03 一.判断类型 is_bool()   判断是否是布尔型 is_int(),is_integer() 和is_long()  判断是否是整型 is_float(),is_double()和i ...

  9. 【Android开发笔记】程序崩溃异常总结

    广播注册相关(broadcastReceiver) 没有注册广播就注销广播 注册广播但未注销广播 注册广播后重复注销广播 解决办法: 添加一个布尔变量,注册广播后为true,若为true在执行注销,注 ...

  10. 利用临时表实现CTE递归查询

    一.CTE递归查询简介 --CTE递归查询终止条件在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递 ...