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

机械公司网站建设对网站提出的优化建议

机械公司网站建设,对网站提出的优化建议,诸暨网络推广,小工程承包的信息平台什么网站真实一、题目解析 对于递归方法的前序遍历十分简单,但对于一位合格的程序猿而言,需要掌握将递归转化为非递归的能力,毕竟递归调用的时候会调用大量的栈帧,存在栈溢出风险。 二、算法原理 递归调用本质是系统建立栈帧,而非…

一、题目解析

对于递归方法的前序遍历十分简单,但对于一位合格的程序猿而言,需要掌握将递归转化为非递归的能力,毕竟递归调用的时候会调用大量的栈帧,存在栈溢出风险。

二、算法原理

递归调用本质是系统建立栈帧,而非递归则是用栈来存储数据,实现类似递归的效果。

首先,我们先简单了解一下递归调用时,是如何遍历的?

前序遍历,由根、左子树、右子树的顺序遍历,打印时直接打印根节点的值。

根据这个我们把它转换到非递归上,对于非递归遍历,左子树节点全部入栈,然后依次访问左子树节点的右子树,由于栈的特性保证后进先出,所以不用担心遍历出错,对于右子树的遍历同样如此,左子树进栈,然后访问右子树。

由此我们可以看出非递归本质上与递归没有多大差别。

三、代码示例

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;}
};

push是栈的入数据操作,top则是栈的获取栈顶元素操作,pop则是栈的删数据操作,push_back是vector的尾插操作

 

四、非递归遍历流程

 

 看到最后,如果对您有所帮助,还请点赞、收藏和关注,点点关注不迷路,我们下期再见!

 

http://www.dtcms.com/wzjs/260282.html

相关文章:

  • 担路做网站全国免费发布信息平台
  • 关于设计方面的网站东莞优化seo
  • 武汉做网站推广哪家好网站关键词快速排名软件
  • 绿盒子网站建设案例青岛网站推广关键词
  • 如何快速提升自己网站搜索优化官网
  • 做明星同款的网站客服系统网页源码2022免费
  • 网站的备案手续百度智能建站系统
  • 纪检网站建设方案google play官网
  • 切实加强政府网站建设与管理制作网页用什么软件
  • 做web网站常用框架百度账户托管运营
  • 代账公司注册条件沈阳优化推广哪家好
  • 宣传片制作公司南京朝阳区seo搜索引擎优化介绍
  • 交易网站seo怎么做网店代运营合同
  • 自学java 做网站 多久企业门户网站模板
  • 网站开发多久能学会做seo排名好的公司
  • 网站代码开发定制线上营销怎么推广
  • 网页网站导读怎么做一站式海外推广平台
  • 深圳网站建设南山移动端排名优化软件
  • 网站是不是每年都要续费深圳全网营销平台排名
  • 网站切版教程百度指数分析平台
  • 做网站收入怎么样口碑营销的模式
  • 用jsp做电影网站的界面seo百度快照优化公司
  • 专门做电脑壁纸网站品牌策划ppt案例
  • 武安网站建设培训平台有哪些
  • 网站开发原始数据惠州百度推广排名
  • 企业公司官网网站女生学网络营销这个专业好吗
  • 网站开发 自我评价百度网盘搜索引擎
  • 中国化学工程第九建设公司网站广东省人大常委会
  • 大连软件公司排行东莞网络排名优化
  • 包车哪个网站做的最好网络营销推广方式案例