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

化工材料 技术支持 东莞网站建设wordpress多重搜索

化工材料 技术支持 东莞网站建设,wordpress多重搜索,网站建设方案有哪几种,wordpress 删除分类非递归遍历二叉树一、二叉树的前序遍历二、二叉树的中序遍历三、二叉树的后序遍历3.1 方法一3.2 方法二一、二叉树的前序遍历 题目链接 我们可以把任何一棵树看成左路节点#xff0c;左路节点和右子树。先访问左路节点#xff0c;再访问左路节点的右子树。在右子树中也重复这… 非递归遍历二叉树一、二叉树的前序遍历二、二叉树的中序遍历三、二叉树的后序遍历3.1 方法一3.2 方法二一、二叉树的前序遍历 题目链接 我们可以把任何一棵树看成左路节点左路节点和右子树。先访问左路节点再访问左路节点的右子树。在右子树中也重复这种循环就是非递归遍历二叉树的思想。 解释 栈st存放节点v存放数值cur初始化为root。 循环条件是栈不为空或者cur不为空(访问最后一个节点之前栈就已经为空了)循环遍历左子树并且把左子树入栈同时把值存入v中。然后弹出栈顶元素并且把栈顶元素的右子树赋值给cur这样就形成了遍历。 当栈不为空的时候说明还有左路节点的右子树没有被访问当cur不为空的时候说明还有树要被访问。当同时为空的时候才是访问完成。当一个节点出栈的时候说明此时该节点及该节点的左子树已经被访问完成了。 class Solution { public:vectorint preorderTraversal(TreeNode* root) {stackTreeNode* st;vectorint v;TreeNode* cur root;while(cur || !st.empty()){while(cur){st.push(cur);v.push_back(cur-val);cur cur-left;}TreeNode* node st.top();st.pop();cur node-right;// 转化成子问题访问右子树}return v;} };二、二叉树的中序遍历 题目链接 因为中序遍历的访问顺序是左根右跟前序遍历不同所以我们让左节点入栈的时候先不访问出栈说明左子树访问完了时在访问节点。 class Solution { public:vectorint inorderTraversal(TreeNode* root) {vectorint v;stackTreeNode* st;TreeNode* cur root;while(!st.empty() || cur){while(cur){st.push(cur);cur cur-left;}TreeNode* node st.top();st.pop();v.push_back(node-val);cur node-right;}return v;} };三、二叉树的后序遍历 3.1 方法一 首先我们知道后序遍历就是左右根而我们可以把访问顺序变成根右左然后再逆置顺序。而根右左就跟前序遍历的方法一样 class Solution { public:vectorint postorderTraversal(TreeNode* root) {stackTreeNode* st;vectorint v;TreeNode* cur root;while(cur || !st.empty()){while(cur){st.push(cur);v.push_back(cur-val);cur cur-right;}TreeNode* node st.top();st.pop();cur node-left;}reverse(v.begin(), v.end());return v;} };3.2 方法二 按照常规的遍历方法走左右根但是这里有一个问题 当访问到根的时候有两种情况 1️⃣ 从左子树回来现在要先访问右子树 2️⃣ 从右子树回来左右子树已经访问完毕再访问根。 针对这种情况我们可以在加一个变量来确定是第几次访问根如果是第一次就访问右子树如果是第二次就访问。 class Solution { public:vectorint postorderTraversal(TreeNode* root) {stackpairTreeNode*, bool st;vectorint v;TreeNode* cur root;while(cur || !st.empty()){while(cur){st.push(make_pair(cur, false));cur cur-left;}TreeNode* node st.top().first;if(st.top().second true){st.pop();v.push_back(node-val);}else{st.top().second true;cur node-right;}}return v;} };
http://www.hkea.cn/news/14285032/

相关文章:

  • 易语言做网站登录器wordpress自动推送token
  • 宿迁公司做网站百度域名是什么
  • 机场建设投资公司官方网站山西建网站
  • 网站推广合作响应式设计是什么意思
  • 潮州市住房和城乡建设局网站做销售记住这十句口诀
  • 网站建设百度优化高性能网站建设进阶
  • 考试网站怎么做的wordpress不居中
  • 网站参考页面设计网络营销的分类
  • 推荐网站建设服务话术网站建设的经费预算报告
  • 全国各大网站开发免费app
  • p2p做网站百度本地推广
  • 响应式设计的网站docker实际企业解决方案
  • 建设品牌网站自己的网站怎么赚钱
  • 网站后台添加投票系统汽车4s店网站建设方案
  • 做网站可行性分析做网站需要买多大空间
  • 企业网站有哪些功能北京vi设计公司广州标志设计
  • 百度四川建设厅网站百度搜索排名购买
  • 东营网站建设推广公司网站被百度收录吗
  • 网站建设哪家最好用wordpress自定义布局
  • 做家具有那个网站好手机百度怎么翻译网页
  • 杭州精品课程网站建设用asp做的大型网站
  • 酒店网站建设的基本内容建设网站要求
  • 网站树状型结构优化彩票网站搭建
  • 四川专业网站建设公司移动端原型
  • 百度免费网站申请现在开天猫店需要多少钱
  • 做电力 公司网站那间公司做网站好
  • 棋牌网站代理北京网站优化合作
  • 网站内容一样影响收录淘宝客网站应该怎么做
  • 代刷网站只做软件下载网站开发协议范本
  • 承德建设网站wordpress+discuz+seo