二叉树前序遍历详解[通俗易懂]

二叉树前序遍历详解[通俗易懂]二叉树的遍历是数据结构中非常基础的内容了,今天这一篇文章我们来详细了解一下二叉树的前序遍历,二叉树的前序遍历顺序是根节点-左子树-右子树,本文对递归和栈模拟的方法都有实现一、递归方法递归方法可以说是很简了,我们秉承先去往左节点再去往右节点的原则就好了//assumethatwehaveTreeNode,andresistostoretheanswervoidpreorder(TreeNode*root,vector<int&.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

二叉树的遍历是数据结构中非常基础的内容了,今天这一篇文章我们来详细了解一下二叉树的前序遍历,二叉树的前序遍历顺序是根节点-左子树-右子树,本文对递归和栈模拟的方法都有实现

一、递归方法

递归方法可以说是很简了,我们秉承先去往左节点再去往右节点的原则就好了

// assume that we have TreeNode, and res is to store the answer 
        
    void preorder(TreeNode *root, vector<int> &res) {
        if (root == nullptr) {
            return;
        }
        res.push_back(root->val); // we will record every node we have traveled
        preorder(root->left, res); // to left first
        preorder(root->right, res); // to right
    }
    

    //main
    vector<int> preorderTraversal(TreeNode *root) {
        vector<int> res;
        preorder(root, res);
        return res;
    }

二、栈实现

我们使用栈迭代来模拟递归的过程,事实上,递归的过程隐式地维护了一个栈,(递归储存了状态,当return 的时候相当于状态集合的.pop() )

具体地:我们将我们从根节点开始遍历到的每一个值都放入我们的答案数组,将遇到的每一个节点都放入节点数组,当节点往一个方向遍历到底(node == NULL) 的时候,我们就要pop这个栈,回到上一层,就像递归的 return 一样

记住:遍历完左边再往右边走,这也是代码中第二个while 的意义

vector<int> preorderTravel (TreeNode root) {
	vector<int> res ; // store the answer
	
	if(root == NULL) {
		return ans ;
	}
	
	stack<TreeNode*> stk ; // store every node we have traveled
	TreeNode *node = root ;
	while(!stk.empty() || node != NULL) {
		while(node != NULL) {
			res.emplace_back(node -> val) ; // push_back,we should every val we met in "preorderTravel"
			stk.emplace(node) ; // push
			node = node -> left ; // go to left frst
		}
		
		node = stk.top() ; 
		stk.pop() ; // same as "return" in recursion
		node = node -> right ;
	}
	
	return res ;
}

本文主要是对栈模拟实现递归的一个练习,如有不正,请指出,感激不尽

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195293.html原文链接:https://javaforall.net

(0)
上一篇 2025年10月20日 上午8:22
下一篇 2025年10月20日 上午9:01


相关推荐

  • 有关QueryInterface函数

    有关QueryInterface函数一,QueryInterface函数原型:HRESULT __stdcall QueryInterface(const IID&iid,void**ppv);iid:标志客户所需的接口。是”一个接口标志符“结构(IID)。ppv:QueryInterface用来存放所请求接口的地址。返回值:可以返回S_OK或E_NOINTERFACE应该用SUCEEDED或者FAILED宏验证

    2022年6月22日
    36
  • 用C语言播放mp3格式的音乐

    用C语言播放mp3格式的音乐目录前言之前有写过在 c 程序里添加背景音乐 用的是 PlaySound 这个函数不过这个函数是只能播放 wav 格式的音乐 这次是用 mciSendStrin 函数可以用来播放 MP3 格式的音乐如何用 c 语言插入 背景 音乐 mciSendStrin 函数简介 mciSendStrin 是用来播放多媒体文件的 API 指令 可以播放 MPEG AVI WAV MP3 等等 需要的头文件 include mmsystem h 基本的播放音乐模板 include windows h i windows h mmsystem h

    2026年3月17日
    2
  • SQL Prompt 激活成功教程教程「建议收藏」

    SQL Prompt 激活成功教程教程「建议收藏」SQLPrompt7激活成功教程教程,SQL语法提示工具本文最新地址:SQLPrompt7激活成功教程教程,SQL语法提示工具链接:https://pan.baidu.com/s/13WIIGx88bfRQE6vcQuFT8w提取码:u2ln当我们在写SQL语句的时候,没有语法提示,效率低,今天给大家分享一款软件以及激活成功教程方法。看下图,是不是很方便了呢?注册机会报毒,安装前请先关闭杀毒软件!…

    2022年7月14日
    30
  • 手把手教学——通过WSL部署OpenClaw(原clawdbot)

    手把手教学——通过WSL部署OpenClaw(原clawdbot)

    2026年3月15日
    3
  • struts定时任务实现(quartz任务调度)

    最近有需求要写一个定时任务目的是更新一些员工/人员与部门之间的关系项目用的是struts2当我加了spring的jar包之后写了一个定时任务项目经理不让用spring就修改一下这次贴个全的下面是任务类packagecom.timetask.action;importjava.io.BufferedWriter;importjava.io.File;importjava….

    2022年4月15日
    46
  • Linux系统安装tomcat7

    Linux系统安装tomcat7Linux上如果尚未安装JDK,可以参考博文https://mp.csdn.net/postedit/801814221.下载Linux版tomcat7,官网即可下载https://tomcat.apache.org/download-70.cgi2.确定好在Linux上你tomcat要放的路径,我的是/usr/tomcat,可以在/usr目录下mkdirtomcat3.将本地tomcat的文件…

    2022年5月24日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号