python中用队列模拟递归(广度遍历)

用队列模拟递归(广度遍历)import osimport collections

def getAllDirQU(path):    queue=collections.deque()    #进队    queue.append(path)

    while len(queue)!=0:        #出队数据        dirPath=queue.popleft()        #找出dirPath所有的文件        filesList=os.listdir(dirPath)

        for fileName in filesList:            #绝对路径            fileAbsPath=os.path.join(dirPath,fileName)            #判断是否是目录,是目录就进队,不是就打印        if os.path.isdir(fileAbsPath):            print("目录:"+fileName)        else:            print("普通文件:"+fileName)

getAllDirQU(r"D:\f\Python\pycharm\234")

原文地址:https://www.cnblogs.com/zlong123/p/10447710.html

时间: 2024-11-01 22:41:07

python中用队列模拟递归(广度遍历)的相关文章

python 队列模拟递归遍历目录(广度遍历)

import osimport collections def getAllDirQU(path): queue = collections.deque() #进队 queue.append(path) while len(queue) != 0: #出队数据 dirPath = queue.popleft() #找出所有的文件 filesList = os.listdir(dirPath) for fileName in filesList: #绝对路径 fileAbsPath = os.pa

队列模拟递归遍历目录(广度遍历)

import os import collections def getALLDir(path): queue = collections.deque()#空的 queue.append(path)#进队 while len(queue) != 0: dirPath = queue.popleft()#数据出队 filesList = os.listdir(dirPath)#找出所有文件 for fileName in filesList:#处理文件 fileAbsPath = os.path.

你知道python的迭代,循环,递归与遍历怎么使用吗?

首先,英文走一波.循环-loop,迭代-iterate,递归-recursion,遍历-travelsal ●循环:指的是在满足条件的情况下,重复执行同一段代码.比如,while语句. ●迭代:指的是按照某种顺序逐个访问列表中的每一项.比如,for语句 ●递归:指的是一个函数不断调用自身的行为.比如,以编程方式输出著名的斐波那契数列. ●遍历:指的是按照一定规律访问树形结构中的每个节点,而且每个节点都只能访问一次. 逐个访问 在python中逐个访问对象中的每个元素,可以这样做:(例如一个lis

数据结构——30行代码实现栈和模拟递归

本文始发于个人公众号:TechFlow,原创不易,求个关注 栈的定义 原本今天想给大家讲讲快速选择算法的,但是发现一连写了好几篇排序相关了,所以临时改了题目,今天聊点数据结构,来看看经典并且简单的数据结构--栈. 栈这个结构我想大家应该都耳熟能详,尤其是在很多地方将和堆并列在一起,称作"堆栈"就更广为人知了.但其实堆和栈本质上是两种不同的数据结构,我们不能简单地混为一谈.让我们先从比较简单的栈开始. 栈和队列的本质其实都是数组(严格地说是线性表).只不过我们在数组上增加了一些限制,使得

图的广度遍历和深度遍历

/* 图的遍历方法主要有两种:一种是深度优先遍历,一种是广度优先遍历.图的深度优先遍历类同于树的先根遍历,图的广度遍历类同树的层次遍历 一:连通图的深度优先遍历算法 图的深度优先遍历算法是遍历时深度优先的算法,即在图的所有邻接顶点中,每次都在访问当前顶点后,首先访问当前顶点的第一个邻接顶点. 连通图的深度优先遍历递归算法如下: 1.访问顶点v并标记顶点v已访问. 2.查找顶点v的第一个邻接顶点w. 3.若顶点v的邻接顶点w存在,则继续执行,否则算法结束. 4.若顶点w尚未被访问,则深度优先遍历递

二叉树的前中后序遍历迭代&广度遍历

递归很是简单 但也应该掌握其迭代方式的遍历方法 这三种的迭代遍历方法需要通过栈来存储节点 尤其是后序遍历还需要 记录当前节点的右子树是否已被遍历 决定是否遍历当前节点 而其广度遍历 只需要一个队列来顺序记录遍历节点 即可轻松解决问题  主要思想在程序代码中来做说明 前序遍历:遍历结果返回一个vector容器中 std::vector<int> BinaryTree::pre_order_iter(Binary_node *root){    std::vector<int> res

数据结构-6-深度广度遍历搜索原理详解

深度广度遍历搜索的定义想必大家都能熟练的掌握了,下面我就通过一个图的实例,把应用的代码直接贴上供大家参考,以后可以直接借鉴或者使用. #include <iostream> #include <string> #include "Queue.h" using namespace std; //图的邻接矩阵存储表示 #define INFINITY INT_MAX #define MAX_VERTEX_NUM 20 typedef enum {DG, DN, UD

数据结构-深度遍历和广度遍历(转)

本文转自http://blog.csdn.net/wingofeagle/article/details/13020373 深度遍历: 从图中某个顶点v出发,访问此顶点,然后从v的未被访问的邻接点出发深度优先遍历图,直至图中所有和v有路径相通的顶点都被访问到. 其更适合:目标比较明确,以找到目标为主要目的的情况. 广度遍历: 类似于树中的层序遍历,首先遍历完和某一顶点v相连的所有顶点,然后再遍历和这些顶点相连的顶点,以此类推. 其更适合于:不断扩大遍历范围时找到相对最优解的情况. 具体代码如下:

二叉树遍历(递归、非递归,层次遍历(从上往下))

递归算法 void preorder1(Node *root) //递归前序遍历 { if (root == NULL) return; printf("%d ", root->val); preorder1(root->left); preorder1(root->right); } void inorder1(Node *root) //递归中序遍历 { if (root == NULL) return; inorder1(root->left); prin