当前位置: 首页 > news >正文

广西安策企业管理咨询有限公司游戏优化大师下载安装

广西安策企业管理咨询有限公司,游戏优化大师下载安装,芙蓉区乡建设局网站,微信开发工具的公司目录 一、先序遍历题目链接1.递归2.非递归 二、中序遍历题目链接1.递归2.非递归 三、后序遍历题目链接1.递归2.非递归 一、先序遍历 先序遍历:先遍历一颗树的根节点,后遍历左子树,最后遍历右子树 先序遍历序列: 1 -> 2 -> 4…

一、先序遍历

先序遍历:先遍历一颗树的根节点,后遍历左子树,最后遍历右子树


在这里插入图片描述

先序遍历序列: 1 -> 2 -> 4 -> 5 -> 3 -> 6 -> 7

题目链接

1.递归

分解子问题方法

class Solution {
public:void preOrder(TreeNode* root,vector<int>& str){if(root==NULL)return;str.push_back(root->val);preOrder(root->left,str);preOrder(root->right,str);}vector<int> preorderTraversal(TreeNode* root) {vector<int> str;preOrder(root,str);return str;}
};

在这里插入图片描述

2.非递归

思路:将一颗二叉树看做两个部分,一个部分是左路节点,另一个部分是左路节点的右子树,先将二叉树的左路节点全部入栈,再依次出栈,出栈的过程中将这个节点的右子树按相同方法将左路节点全部入栈,然后依次出栈,出栈的方法与上面相同,模拟递归调用的方法实现非递归,此时的入栈顺序就是先序遍历序列
在这里插入图片描述
在这里插入图片描述

class Solution {
public:vector<int> preorderTraversal(TreeNode* root) {stack<TreeNode*> st;TreeNode* cur=root;vector<int> v;while(cur||!st.empty()){//访问一棵树的开始//  1、访问左路节点,左路节点入栈,后续一次访问左路节点的右子树while(cur){v.push_back(cur->val);st.push(cur);cur=cur->left;}//一次访问左路节点的右子树TreeNode* top=st.top();st.pop();//子问题的方式访问右子树cur=top->right;}return v;}
};

二、中序遍历

题目链接

中序遍历:先遍历一颗树的左子树,然后遍历根节点,最后遍历右子树
在这里插入图片描述

中序遍历序列:4 -> 2 -> 5 -> 1 -> 6 -> 3 -> 7

1.递归

递归调用分解子问题,与前序遍历递归思路相同

class Solution {
public:void inorder(TreeNode* root,vector<int>& res){if(root==NULL)return;inorder(root->left,res);res.push_back(root->val);inorder(root->right,res);}vector<int> inorderTraversal(TreeNode* root) {vector<int> res;inorder(root,res);return res;}
};

2.非递归

与前序遍历相似,前序遍历是在入栈的顺序为前序遍历序列,而中序遍历则是出栈的顺序则为中序遍历序列
在这里插入图片描述
在这里插入图片描述

class Solution {
public:vector<int> inorderTraversal(TreeNode* root) {stack<TreeNode*> st;TreeNode* cur=root;vector<int> v;while(cur||!st.empty()){//访问一棵树的开始//  1、访问左路节点,左路节点入栈,后续一次访问左路节点的右子树while(cur){st.push(cur);cur=cur->left;}//一次访问左路节点的右子树TreeNode* top=st.top();st.pop();v.push_back(top->val);//子问题的方式访问右子树cur=top->right;}return v;}
};

三、后序遍历

后序遍历:先遍历一颗树的左子树,然后遍历右子树,最后遍历根节点
在这里插入图片描述

后续遍历序列:4 -> 5 -> 2 -> 6 -> 7 -> 3 -> 1

题目链接

1.递归

分解子问题

class Solution {
public:void postOrder(TreeNode* root,vector<int>& ret){if(root==NULL)return;postOrder(root->left,ret);postOrder(root->right,ret);ret.push_back(root->val);}vector<int> postorderTraversal(TreeNode* root) {vector<int> ret;postOrder(root,ret);return ret;}
};

2.非递归

后续遍历的非递归要比前序和中序遍历的非递归复杂一点,我们要在前面前序遍历和中序遍历非递归的算法上进行一些改进,创建一个变量prev,用来记录访问当前节点的上一个节点,如果当前左路节点的右子树为空或者已经访问过右子树就需将当前接节点出栈,此时的出栈顺序即为后续遍历序列。
在这里插入图片描述
在这里插入图片描述

class Solution {
public:vector<int> postorderTraversal(TreeNode* root) {stack<TreeNode*> st;TreeNode* cur=root;TreeNode* prev=NULL;vector<int> v;while(cur||!st.empty()){//访问一棵树的开始//  1、访问左路节点,左路节点入栈,后续一次访问左路节点的右子树while(cur){st.push(cur);cur=cur->left;}TreeNode* top=st.top();//一个节点右子树为空或者上一个访问节点是右子树的根,说明右子树访问过滤,可以访问根节点了if(top->right==nullptr||top->right==prev){prev=top;v.push_back(top->val);st.pop();}else cur=top->right;}return v;}
};
http://www.dinnco.com/news/45059.html

相关文章:

  • 广告册设计公司seo网站推广价格
  • 动画形式的h5在哪个网站做做百度关键词排名的公司
  • 润才网站建设广告语
  • 视频做动图的网站疫情防控最新信息
  • 青海网站建设哪家好做直销去哪里找客户
  • 哪些做调查问卷挣钱的网站如何做推广
  • 做公司网站需要准备什么自己怎么制作网站
  • 建筑二级建造师培训机构优化设计六年级下册语文答案
  • 网站怎么做二维码链接地址手机端网站优化
  • 宜兴网站建设360外链
  • 天津河北做网站的公司简单制作html静态网页
  • 招聘网站数建设有没有免费推广平台
  • 做汽车配件网站的公司山西优化公司
  • 编程就是做网站吗自己开发网站怎么盈利
  • 淘宝客服推销做网站的技巧互联广告精准营销
  • 杭州网站建设杭州沃迩夫营销型网站建设的步骤流程是什么
  • 湖北建设厅政务网站搜索引擎排名优化是什么意思
  • 云南网站做的好的公司网络市场调研的五个步骤
  • 企业管理系统大全免费网站优化seo推广服务
  • 用c 做一个小网站怎么做关键词举例
  • 即墨网站建设哪家好百度注册网站
  • wordpress教程视频教程关键词优化精灵
  • 做电影网站违法么现在网络推广方式
  • 装修公司网站建设药品销售推广方案
  • 网站首页标题设置2021关键词搜索排行
  • 网站建设后台管理便捷快速建站
  • 北京东直门网站建设最近时事热点
  • 做网站建设的企业还有那些百度seo不正当竞争秒收
  • 自己做一个商城网站怎么做免费做网站怎么做网站吗
  • 武汉做网站推广百度推广运营专员