一步一步学数据结构之n--n(图遍历--深度优先遍历--非递归实现)
前面已经说了图的深度优先遍历算法,是用递归实现的,而在这里就讲一下用非递归实现,需要借助栈:
算法思想:
1. 栈初始化
2. 输出起始顶点,起始顶点改为“已访问”标志,将起始顶点进栈
3. 重复下列操作直到栈为空:
3.1 取栈顶元素顶点
3.2 栈顶元素顶点存在未被访问过的邻接点w,则:
3.2.1 输出顶点w
3.2.2 将顶点w改为“已访问”标志
3.2.3 将顶点w进栈
3.3 否则,当前顶点出栈
非递归实现深度优先遍历(邻接链表法)
static void orther_dfs(TLGraph* tGraph, int v, int visited[], LGraph_Printf* pFunc)
{
LinkStack* stack = LinkStack_Create(); LinkStack_Push(stack, tGraph->v + v); while(!LinkStack_Empty(stack))
{
int w = (LVertex**)LinkStack_Top(stack) - tGraph->v; LinkStack_Pop(stack); if(!visited[w])
{
int i = 0; pFunc(tGraph->v[w]); visited[w] = 1; for(i=0; i<LinkList_Length(tGraph->la[v]); i++)
{
if(!visited[i])
{
LinkStack_Push(stack, tGraph->v + i);
}
}
}
} LinkStack_Destroy(stack);
} void LGraph_DFS_Orther(LGraph* graph, int v, LGraph_Printf* pFunc)
{
TLGraph* tGraph = (TLGraph*)graph; int* visited = NULL; int condition = (NULL != tGraph);
condition = condition && (0 <= v) && (v < tGraph->count);
condition = condition && (NULL != pFunc);
condition = condition && (NULL != (visited = (int*)calloc(tGraph->count, sizeof(int)))); if(condition)
{
int i = 0; orther_dfs(tGraph, v, visited, pFunc); for(i=0; i<tGraph->count; i++)
{
if(!visited[i])
{
orther_dfs(tGraph, i, visited, pFunc);
}
} printf("\n");
} free(visited);
}
非递归实现深度优先遍历(邻接矩阵法)
static void orther_dfs(TMGraph* tGraph, int v, int visited[], MGraph_Printf* pFunc)
{
LinkStack* stack = LinkStack_Create(); LinkStack_Push(stack, tGraph->v + v); while(!LinkStack_Empty(stack))
{
int w = (MVertex**)LinkStack_Top(stack) - tGraph->v; LinkStack_Pop(stack); if(!visited[w])
{
int i = 0; pFunc(tGraph->v[w]); visited[w] = 1; for(i=0; i<LinkList_Length(tGraph->count); i++)
{
if((0!=tGraph->matrix[v][i]) && (!visited[i]))
{
LinkStack_Push(stack, tGraph->v + i);
}
}
}
} LinkStack_Destroy(stack);
} void MGraph_DFS_Orther(MGraph* graph, int v, MGraph_Printf* pFunc)
{
TMGraph* tGraph = (TMGraph*)graph; int* visited = NULL; int condition = (NULL != tGraph);
condition = condition && (0 <= v) && (v < tGraph->count);
condition = condition && (NULL != pFunc);
condition = condition && (NULL != (visited = (int*)calloc(tGraph->count, sizeof(int)))); if(condition)
{
int i = 0; orther_dfs(tGraph, v, visited, pFunc); for(i=0; i<tGraph->count; i++)
{
if(!visited[i])
{
orther_dfs(tGraph, i, visited, pFunc);
}
} printf("\n");
} free(visited);
}
一步一步学数据结构之n--n(图遍历--深度优先遍历--非递归实现)的更多相关文章
- 重新整理数据结构与算法(c#)—— 图的深度遍历和广度遍历[十一]
参考网址:https://www.cnblogs.com/aoximin/p/13162635.html 前言 简介图: 在数据的逻辑结构D=(KR)中,如果K中结点对于关系R的前趋和后继的个数不加限 ...
- 数据结构——图的深度优先遍历(邻接矩阵表示+java版本)
1.深度优先遍历(DFS) 图的深度优先遍历本质上是一棵树的前序遍历(即先遍历自身,然后遍历其左子树,再遍历右子树),总之图的深度优先遍历是一个递归的过程. 如下图所示,左图是一个图,右图是图的深度 ...
- 嗯,ACM按照这个一步一步来。
转一个搞ACM需要的掌握的算法. 要注意,ACM的竞赛性强,因此自己应该和自己的实际应用联系起来. 适合自己的才是好的,有的人不适合搞算法,喜欢系统架构,因此不要看到别人什么就眼红, 发挥 ...
- 数据结构-树以及深度、广度优先遍历(递归和非递归,python实现)
前面我们介绍了队列.堆栈.链表,你亲自动手实践了吗?今天我们来到了树的部分,树在数据结构中是非常重要的一部分,树的应用有很多很多,树的种类也有很多很多,今天我们就先来创建一个普通的树.其他各种各样的树 ...
- 一步一步学ROP之linux_x64篇
一步一步学ROP之linux_x64篇 一.序 **ROP的全称为Return-oriented programming(返回导向编程),这是一种高级的内存攻击技术可以用来绕过现代操作系统的各种通用防 ...
- 一步一步学ROP之linux_x86篇
一步一步学ROP之linux_x86篇 作者:蒸米@阿里聚安全 一.序 ROP的全称为Return-oriented programming(返回导向编程),这是一种高级的内存攻击技术可以用来绕过 ...
- 一步一步跟我学DeviceOne开发 - 仿微信应用(一,二,三)
这是一个系列的文档,长期目标是利用DeviceOne开发一些目前使用广泛的优质手机应用,我们会最大化的实现这些应用的每一个功能和细节,不只停留在简单的UI模仿和Demo阶段,而是一个基本可以使用的实际 ...
- (转载)一步一步学Linq to sql系列文章
现在Linq to sql的资料还不是很多,本人水平有限,如果有错或者误导请指出,谢谢. 一步一步学Linq to sql(一):预备知识 一步一步学Linq to sql(二):DataContex ...
- 一步一步学ZedBoard & Zynq(四):基于AXI Lite 总线的从设备IP设计
本帖最后由 xinxincaijq 于 2013-1-9 10:27 编辑 一步一步学ZedBoard & Zynq(四):基于AXI Lite 总线的从设备IP设计 转自博客:http:// ...
随机推荐
- EXPORT_SYMBOL的作用是什么
http://www.cnblogs.com/riskyer/p/3221805.html EXPORT_SYMBOL只出现在2.6内核中,在2.4内核默认的非static 函数和变量都会自动 导入到 ...
- 华为P6-U06 ROOT
移动.联通.电信版P6均可成功的EMUI3.0开发版/稳定版 ROOT... - P6/P6s 花粉俱乐部 http://cn.club.vmall.com/forum.php?mod=viewthr ...
- python string 连接test
def strTest(): name = "" for i in range(10): name += "hello" #print name def str ...
- SGU111 Very simple problem
多少个平方数小于等于X,二分. PS:java BigInteger. import java.util.*; import java.math.*; public class Solution { ...
- EPEL库安装
EPEL是yum的一个软件源,里面包含了许多基本源里没有的软件了,但在我们在使用epel时是需要安装它才可以了.EPEL,即Extra Packages for Enterprise Linux的简称 ...
- 【ZOJ】3609 Modular Inverse
1. 题目描述求乘法逆元. 2. 基本思路利用扩展gcd求逆元,模板题目. 3. 代码 /* 3609 */ #include <iostream> #include <sstrea ...
- 'ascii' codec can't encode characters in position 0-8: ordinal not in range(128)的解决办法
使用的python2.7,运行的时候出现了'ascii' codec can't encode characters in position 0-8: ordinal not in range(128 ...
- poj2229
很不错的一道题,这里提供两种方法: 方法1:递推: 易知当n为奇数时,f[n]=f[n-1] (n-1的所有方案前面添1,并且没有新的方案): 重点是n为偶数的时候,则拆分方案中,要么有偶数个1,要么 ...
- BZOJ2893: 征服王
题解: 裸的上下界最小流是有问题的.因为在添加了附加源之后求出来的流,因为s,t以及其它点地位都是平等的.如果有一个流经过了s和t,那么总可以认为这个流是从s出发到t的满足题意的流. 既然可能存在s到 ...
- SCOI2010 and SXOI2014 股票交易(DP)
明显的单调队列…… 但下面的程序一直有bug 附上题解:http://blog.csdn.net/njlcazl/article/details/8611042 附上我的代码: var head,ta ...