图 -数据结构(C语言实现)
读数据结构与算法分析
坑!待填!
若干定义
- 一个图G = (V , E)由顶点集V和边集E组成,每条边就是一个点对
- 如果点对是有序的,那么就叫做有向图
- 边可能还具有第三种成分,权值
- 无向图种从每个顶点到其他每个顶点都存在至少一天路径,则称为图是连通的。具有这样性质的有向图称为强连通,如果不是强连通的,但它的基础图是连通的,则称为弱连通
图的表示
领接矩阵
- 使用一个二维数组表示
- 对于每条边(u,v),置A[u][v] = 1;
邻接表
- 用一个表来储存这个顶点的所有邻接点
- 使用一个数组保存头单元
- 每个头单元连接着所有顶点
拓扑排序
对有向无圈的顶点的一种排序,使得如果存在从vi到vj,那么在排序中vj必须出现在vi后面
实现
简单实现
- 从有向图中选取一个没有前驱(入度为0)的顶点,并输出之;
- 从有向图中删去此顶点以及所有以它为尾的弧(弧头顶点的入度减1);
- 重复上述两步,直至图空,或者图不空但找不到无前驱的顶点为止。
类型声明
typedef char VertexType ;
typedef struct OutNode *Degree ;
typedef struct GVertex *Vertex ;
struct OutNode
{
VertexType Date ;
Degree Next ;
}
struct GVertex
{
int in ;
VertexType Date ;
Degree First ;
}
主函数
int Getin(Vertex G)
{
int len = 0;
while((G++)->Data != '/0')
len ++ ;
return len ;
}
void TopSort(Vertex G)
{
int i,j,k ;
Degree P;
int VertexNum ;
VertexNum = Getin(G) ;
for(i = 0; i < VertexNum; i++)
for(j = 0;j < VertexNum; j++)
if(G[j].in === 0)
{
printf("%c ", G[j].data);
G[j].in = -1;
P = G[j].first ;
while(P != NULL)
{
for( k=0; k<VertexNum; k++ )
if( P->data == G[k].data ) {
G[k].in--;
break;
}
P = P->next;
}
break ;
}
}
无权单源最短路算法
基本思路:按照BFS的思路搜索图,并记下路径长
void Unweihted(Table T)
{
int CurrDist ;
Vertex V, W ;
for(Currist = 0; Currist < NumVertex; Currist++)
for each vertex V
if(!T[v].Known && T[v].Dist == Currist)
{
T[v].Known = True ;
for each W adjacent to V
if(T[W].Dist == Infinity)
{
T[W].Dist = CurrDist + 1 ;
T[W].Path = V ;
}
}
}
更高效率的
void Unweighted(Table T)
{
Queue Q ;
Vertex V, W ;
Q = CreateQueue(NumVertex) ;
MakeEmpty(Q) ;
while(!IsEmpty(Q))
{
V = Dequeue(Q) ;
T[V].Known = True ;
for each W adjacent to V
if(T[W].Dist == Infinity)
{
T[W].Dist == T[W].Dist + 1;
T[W].Path = V ;
Enqueue(W,Q) ;
}
}
DisposeQueue(Q) ;
}
DFS深度优先搜索模板
void dfs(Vertex V)
{
Visited[V] = True ;
for each W adjacent to V
if(!Visted[W])
dfs(W) ;
}
``
图 -数据结构(C语言实现)的更多相关文章
- 图的存储结构大赏------数据结构C语言(图)
图的存储结构大赏------数据结构C语言(图) 本次所讲的是常有的四种结构: 邻接矩阵 邻接表 十字链表 邻接多重表 邻接矩阵 概念 两个数组,一个表示顶点的信息,一个用来表示关联的关系. 如果是无 ...
- 数据结构C语言版 有向图的十字链表存储表示和实现
/*1wangxiaobo@163.com 数据结构C语言版 有向图的十字链表存储表示和实现 P165 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h> ...
- 数据结构C语言版 弗洛伊德算法实现
/* 数据结构C语言版 弗洛伊德算法 P191 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h>#include <limits.h> # ...
- c++学习书籍推荐《清华大学计算机系列教材:数据结构(C++语言版)(第3版)》下载
百度云及其他网盘下载地址:点我 编辑推荐 <清华大学计算机系列教材:数据结构(C++语言版)(第3版)>习题解析涵盖验证型.拓展型.反思型.实践型和研究型习题,总计290余道大题.525道 ...
- 数据结构C语言版 表插入排序 静态表
数据结构C语言版 表插入排序.txt两个人吵架,先说对不起的人,并不是认输了,并不是原谅了.他只是比对方更珍惜这份感情./* 数据结构C语言版 表插入排序 算法10.3 P267-P270 编译 ...
- 《数据结构-C语言版》(严蔚敏,吴伟民版)课本源码+习题集解析使用说明
<数据结构-C语言版>(严蔚敏,吴伟民版)课本源码+习题集解析使用说明 先附上文档归类目录: 课本源码合辑 链接☛☛☛ <数据结构>课本源码合辑 习题集全解析 链接☛☛☛ ...
- 数据结构(C语言)—排序
数据结构(C语言)—排序 排序 排序是按关键字的非递增或递减顺序对一组记录中心进行排序的操作.(将一组杂乱无章的数据按一定规律顺次排列起来.) 未定列表与不稳定列表 假设 Ki = Kj ( 1 ≤ ...
- 【图数据结构的遍历】java实现广度优先和深度优先遍历
[图数据结构的遍历]java实现广度优先和深度优先遍历 宽度优先搜索(BFS)遍历图需要使用队列queue数据结构: 深度优先搜索(DFS, Depth First Search)的实现 需要使用到栈 ...
- Python语言数据结构和语言结构(2)
目录 1. Python预备基础 2. Python数据类型 3. Python条件语句 4. while循环和for循环 1. Python预备基础 1.1 变量的命名 变量命名规则主要有以下几 ...
- 一幅图解决R语言绘制图例的各种问题
一幅图解决R语言绘制图例的各种问题 用R语言画图的小伙伴们有木有这样的感受,"命令写的很完整,运行没有报错,可图例藏哪去了?""图画的很美,怎么总是图例不协调?" ...
随机推荐
- 【noip模拟赛 王强的疑惑】 题解
考试题. 是个DP. 50分可以通过子集枚举+线段覆盖(贪心)完成. 考试没时间写了一个子集枚举30分. #include <cstdio> #include <cstring> ...
- struts2的动态方法调用(DMI)和通配符映射
动态方法调用 1.Struts2默认关闭DMI功能,需要使用需要手动打开,配置常量 struts.enable.DynamicMethodInvocation = true 2.使用“!”方法,即 ...
- PDO介绍(16)
安装PDO PDO的数据选项 链接到数据库服务器并选择数据库 错误处理 获取和设置属性 查询执行 准备语句介绍 获取数据 设置绑定列 处理事务
- 【.net开发者自学java系列】使用Eclipse开发SpringMVC(1)
第一篇随笔,有点紧张.有错别字是正常的.... 好了,自我描述下.我是一个有几年.net开发经验的老菜鸟.是的,老菜鸟.别跟我讨论底层,别跟我讨论协议.TMD啥都不会. 为什么要学JAVA,我也不想, ...
- rman基础知识理解(一)
rman用于对数据库的备份和恢复. 他的命令主要分成两大类:独立命令和批处理命令: 独立命令只能在rman的提示符下执行,主要的命令有: CONNECT CONFIGURE CREATE CATALO ...
- 面试官问你JS基本类型时他想知道什么?
面试的时候我们经常会被问答js的数据类型.大部分情况我们会这样回答包括:1.基本类型(值类型或者原始类型): Number.Boolean.String.NULL.Undefined以及ES6的Sym ...
- iOS双滑块选择器
iOS双滑块选择器 <SDRangeSliderView> https://github.com/qddnovo/SDRangeSliderView 实现了通用性和便利性 今天是个好日子
- LR--用栈实现移进--归约分析(demo)
1.考虑文法 \(E->E+E\) \(E->E*E\) \(E->id\) 2.最右推导 不难看出,这个文法是而二义的,所以有多个最右推导 3.移进归约 用一个栈存文法符号,用输入 ...
- 局域网内python socket实现windows与linux间简单的消息传送
有个需求,就是在windows上看见一篇介绍linux相关的文章,想在局域网内的另外一台linux电脑上尝试一下, 于是就需要把该网页链接发送给linux,不想一点一点敲链接,又苦于没有找到其它好的方 ...
- 基于CLGeocoder - 反地理编码
iOS中CoreLocatio框架中的CLGeocoder 类不但为我们提供了地理编码方法,而且还提供了反地理编码: 同样需要导入框架: #import <CoreLocation/CoreLo ...