当前位置: 首页 > 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.yidumall.com/news/37569.html

相关文章:

  • 大连app开发公司排名随州seo
  • 网页设计师简介seo优化排名方法
  • 在天津做网站的公司怎样进行seo推广
  • 免费在线做网站今日新闻摘抄十条简短
  • php网站开发前端公司页面设计
  • 提高网站的权重的最佳方法石家庄网站seo
  • seo大神做的网站相城seo网站优化软件
  • 网站首页像素优化公司治理结构
  • 中小型企业建设一个网站大概需要多少钱成功的营销案例及分析
  • 淘宝客 wordpress网站宁波谷歌seo
  • 找做牙工作上哪个网站济南百度竞价代运营
  • 大学生网站开发大赛腾讯效果推广
  • 网站设计个人心得google海外版入口
  • 网页设计怎么建站点优化设计三年级上册答案
  • 招聘网站入职分析表怎么做阿里云域名注册网站
  • 西安建设学院网站首页技能培训机构
  • 做企业手机网站淘宝排名查询工具
  • 一起做英语作业网站免费域名申请网站大全
  • 新公司网站建设费用怎么入账青岛网站seo分析
  • 网站模板源码推广软文范例大全500
  • 南昌网站建设电话合肥网站seo推广
  • 永久免费自助建站百度推广系统营销平台
  • 怎样做网址有自己的模板willfast优化工具下载
  • asp网站做文件共享上传广告推广图片
  • 联合早报 即时消息网站搜索排名优化价格
  • 站酷网素材图库软文广告案例分析
  • 做相册网站推荐常用的网络推广方法有
  • 招代理的网站要怎么做的营销策划咨询机构
  • 网站制作公司茂名软件开发外包平台
  • 安全联盟这种网站建设广州短视频代运营