数据结构递归与非递归

时间: 2023-11-26 21:42:56 浏览: 29
非递归DFS是使用堆栈(stack)实现的深度优先搜索算法。首先,将起始节点压入堆栈中,然后进入循环,直到堆栈为空。在循环中,取出堆栈顶部的节点,遍历其所有的邻居节点,并将邻居节点压入堆栈中。同时,输出当前节点的值。这样就能按照深度优先的方式遍历整个图或树结构。 递归DFS则是通过递归函数实现的深度优先搜索算法。首先,从起始节点开始,遍历其所有的邻居节点,并对每个邻居节点递归调用DFS函数。在DFS函数中,再次遍历当前节点的邻居节点,并进行递归调用。不断递归下去,直到没有未访问的邻居节点为止。在递归的过程中,输出每个节点的值。 非递归DFS和递归DFS都是常用的图遍历方法,用于解决一些与图相关的问题。
相关问题

数据结构递归和非递归遍历二叉树的报告

二叉树是一种非常基础和重要的数据结构,对于理解递归和非递归的遍历方式也有很大的帮助。本文将介绍二叉树的前序、中序、后序的递归和非递归遍历方式,并对它们进行比较和分析。 ### 前序遍历 前序遍历的顺序是:先遍历根节点,然后遍历左子树,最后遍历右子树。递归方式的代码如下: ```python def preorder_recursive(root): if not root: return print(root.val) preorder_recursive(root.left) preorder_recursive(root.right) ``` 非递归方式的代码如下: ```python def preorder_iterative(root): if not root: return stack = [root] while stack: node = stack.pop() print(node.val) if node.right: stack.append(node.right) if node.left: stack.append(node.left) ``` 可以看出,非递归方式使用了一个栈来模拟递归过程。首先把根节点入栈,然后每次取出栈顶元素,并打印它的值。如果有右孩子,就把右孩子入栈;如果有左孩子,就把左孩子入栈。这样,就能保证在遍历到一个节点时,它的左子树已经全部遍历完了。 ### 中序遍历 中序遍历的顺序是:先遍历左子树,然后遍历根节点,最后遍历右子树。递归方式的代码如下: ```python def inorder_recursive(root): if not root: return inorder_recursive(root.left) print(root.val) inorder_recursive(root.right) ``` 非递归方式的代码如下: ```python def inorder_iterative(root): if not root: return stack = [] node = root while stack or node: if node: stack.append(node) node = node.left else: node = stack.pop() print(node.val) node = node.right ``` 可以看出,非递归方式同样使用了一个栈来模拟递归过程。首先把根节点入栈,并把指针指向左子树的最底层。然后每次取出栈顶元素,并打印它的值。如果有右孩子,就把右孩子入栈;如果没有右孩子,就返回到它的父节点。 ### 后序遍历 后序遍历的顺序是:先遍历左子树,然后遍历右子树,最后遍历根节点。递归方式的代码如下: ```python def postorder_recursive(root): if not root: return postorder_recursive(root.left) postorder_recursive(root.right) print(root.val) ``` 非递归方式的代码如下: ```python def postorder_iterative(root): if not root: return stack = [root] res = [] while stack: node = stack.pop() res.append(node.val) if node.left: stack.append(node.left) if node.right: stack.append(node.right) return res[::-1] ``` 可以看出,非递归方式同样使用了一个栈来模拟递归过程。首先把根节点入栈,在遍历完左子树和右子树之后,把它的值加入到结果列表中。最后,把结果列表翻转,就得到了后序遍历的结果。 ### 比较和分析 递归和非递归遍历方式的时间复杂度都是 O(n),空间复杂度也都是 O(n)。但是,非递归方式需要使用一个栈来模拟递归过程,所以空间复杂度比递归方式要高。而且,非递归方式的代码比较难理解和实现,需要仔细分析。 另外,对于前序和后序遍历,非递归方式的代码比递归方式要复杂一些,需要添加一些特判来保证遍历顺序的正确性。而中序遍历的非递归方式比较简单,只需要一个栈和一个指针即可。 总的来说,递归方式比较简洁和易于理解,但是可能会因为递归深度过大而导致栈溢出。非递归方式虽然可以避免这个问题,但是代码比较复杂,需要一定的实现技巧和思维难度。所以,在实际应用中,根据具体情况选择合适的遍历方式比较重要。

图的深度优先遍历非递归 数据结构

图的深度优先遍历非递归的数据结构通常使用栈来保存中间变量。栈是一种后进先出(LIFO)的数据结构,它可以保存当前节点的信息以便后续处理。在深度优先遍历中,我们首先将起始节点入栈,然后依次将与当前节点相连的未访问过的节点入栈,直到没有未访问的相邻节点。此时,我们将栈顶节点出栈,并将其作为当前节点继续遍历。重复这个过程,直到栈为空为止。 具体实现时,我们可以使用一个辅助栈来保存未访问的节点。每次从栈中弹出一个节点时,我们将其标记为已访问,并将其未访问的相邻节点入栈。这样,我们就可以按照深度优先的顺序遍历图中的所有节点。 需要注意的是,为了避免重复遍历已经访问过的节点,我们需要在节点被访问时将其标记为已访问。这可以通过一个额外的布尔数组或哈希表来实现。 综上所述,图的深度优先遍历非递归的数据结构是栈。我们可以使用栈来保存未访问的节点,并按照深度优先的顺序遍历图中的所有节点。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [二叉树的深度优先遍历非递归深度解析](https://blog.csdn.net/zhanghuaichao/article/details/124243582)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

相关推荐

最新推荐

recommend-type

C++ 数据结构二叉树(前序/中序/后序递归、非递归遍历)

主要介绍了C++ 数据结构二叉树(前序/中序/后序递归、非递归遍历)的相关资料,这里提供实例代码来帮助大家理解掌握二叉树,需要的朋友可以参考下
recommend-type

C++使用递归和非递归算法实现的二叉树叶子节点个数计算方法

主要介绍了C++使用递归和非递归算法实现的二叉树叶子节点个数计算方法,涉及C++二叉树的定义、遍历、统计相关操作技巧,需要的朋友可以参考下
recommend-type

数据结构课程设计二叉树的非递归遍历

数据结构 课程设计二叉树的非递归遍历 对任意给定的二叉树(顶点数自定)建立它的二叉链表存贮结构,并利用栈的五种基本运算(置空栈、进栈、出栈、取栈顶元素、判栈空)实现二叉树的先序、中序、后序三种遍历,输出...
recommend-type

数据结构综合课设二叉树的建立与遍历.docx

1.问题描述: 建立一棵二叉树,并对其进行遍历(先序、中序、后序),打印输出遍历结果。 2.基本要求: 从键盘接受输入(先序),以二叉链表作为存储结构,建立二叉树(以先序来建立...采用非递归算法实现二叉树遍历。
recommend-type

数据结构c语言版建立二叉树,中序非递归遍历(实验报告)

编写程序,用先序递归的方法建立二叉树,建立二叉树后,用中序非递归方法遍历该二叉树,并输出遍历序列。
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

Redis验证与连接:快速连接Redis服务器指南

![Redis验证与连接:快速连接Redis服务器指南](https://img-blog.csdnimg.cn/20200905155530592.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzMzNTg5NTEw,size_16,color_FFFFFF,t_70) # 1. Redis验证与连接概述 Redis是一个开源的、内存中的数据结构存储系统,它使用键值对来存储数据。为了确保数据的安全和完整性,Redis提供了多
recommend-type

gunicorn -k geventwebsocket.gunicorn.workers.GeventWebSocketWorker app:app 报错 ModuleNotFoundError: No module named 'geventwebsocket' ]

这个报错是因为在你的环境中没有安装 `geventwebsocket` 模块,可以使用下面的命令来安装: ``` pip install gevent-websocket ``` 安装完成后再次运行 `gunicorn -k geventwebsocket.gunicorn.workers.GeventWebSocketWorker app:app` 就不会出现这个报错了。
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。