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

做外贸营销网站销售咋样网站制作免费

做外贸营销网站销售咋样,网站制作免费,做网站常用哪种语言,给一个学校网站做宣传海报目录 ​编辑 一#xff0c;前序遍历 题目接口#xff1a; 递归解法#xff1a; 非递归解法#xff1a; 二#xff0c;中序遍历 题目接口#xff1a; 递归解法#xff1a; 非递归写法#xff1a; 三#xff0c;后序遍历 题目接口#xff1a; 递归解法前序遍历 题目接口 递归解法 非递归解法 二中序遍历 题目接口 递归解法 非递归写法 三后序遍历 题目接口 递归解法 非递归解法 一前序遍历 题目接口 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/ class Solution { public:vectorint preorderTraversal(TreeNode* root) {} }; 递归解法 对于这道题相信大家都能够轻松解决掉。递归写法非常简单 class Solution { public:void _preorderTraversal(TreeNode*root, vectorintret){if(root nullptr){return ;}ret.push_back(root-val);_preorderTraversal(root-left, ret);_preorderTraversal(root-right,ret);}vectorint preorderTraversal(TreeNode* root) {vectorintret;_preorderTraversal(root,ret);return ret;} }; 非递归解法 但是如果要你写出一个非递归版本的的写法呢我们该如何写呢步骤如下 1. 搞一个栈这个栈的作用是存下每一个节点。 2.定义一个cur指针指向当前节点。然后从该节点cur开始使用一个小循环循环遍历左子树在将一个左子树遍历完以后也就是遍历到nullptr以后便结束循环。 3.取栈顶元素top让cur重新指向top的右指针。然后从新的cur开始重新遍历左子树。 4.当栈为空且cur为nullptr时便可以结束大循环返回得到的前序遍历的结果。 代码如下 class Solution { public:vectorint preorderTraversal(TreeNode* root) {vectorintret;//存储结果的数组stackTreeNode*st;//栈TreeNode*cur root;while(!st.empty()||cur)//循环结束条件必须在两者都是nullptr的情况下才能结束循环。{while(cur){ret.push_back(cur-val);st.push(cur);cur cur-left;}TreeNode* top st.top();st.pop();cur top-right;//指向右节点遍历右树。}return ret;} }; 总结这里的关键一步便是遍历每一个节点的左树。然后将每一个节点用栈记录下来。这里为什么要使用栈呢这是利用了栈后进先出的特点由于在电脑上画图比较麻烦所以大家可以自己根据这个代码画图模拟一下。 二中序遍历 题目接口 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/ class Solution { public:vectorint inorderTraversal(TreeNode* root) {} }; 递归解法 使用递归解法任仍然是简单的也就是按照顺序左子树-根-右子树的顺序来递归遍历这棵二叉树。代码如下 class Solution { public:void _inorderTraversal(TreeNode*root, vectorintin){if(root nullptr){return;}_inorderTraversal(root-left,in);in.push_back(root-val);_inorderTraversal(root-right,in);}vectorint inorderTraversal(TreeNode* root) {vectorintin;_inorderTraversal(root,in);return in;} }; 非递归写法 有了上面的前序遍历的非递归写法的思想以后中序遍历的非递归写法就好写很多了。我们只需要在前序遍历的非递归写法上改一下根节点插入到in数组中的顺序便可以了。代码如下 class Solution { public:vectorint inorderTraversal(TreeNode* root) {vectorintret;//存储结果的数组stackTreeNode*st;//栈TreeNode*cur root;while(!st.empty()||cur)//循环结束条件必须在两者都是nullptr的情况下才能结束循环。{while(cur)//这个循环只往栈st里面插入插入节点的指针而不往ret里面插入值{st.push(cur);cur cur-left;}TreeNode* top st.top();ret.push_back(top-val);//在这里才插入值st.pop();cur top-right;//指向右节点遍历右树。}return ret;} }; 三后序遍历 题目接口 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/ class Solution { public:vectorint postorderTraversal(TreeNode* root) {} }; 递归解法 这道题的递归解法仍然很简单就是按照左子树-右子树-根的顺序遍历这棵二叉树。递归代码如下 class Solution { public:void _postorderTraversal(TreeNode*root,vectorintret){if(root nullptr){return;}_postorderTraversal(root-left,ret);_postorderTraversal(root-right,ret);ret.push_back(root-val);}vectorint postorderTraversal(TreeNode* root) {vectorintret;_postorderTraversal(root,ret);return ret;} }; 非递归解法 这道题难就难在非递归解法的代码我们该如何去写呢难就难在这里了。首先我们也都知道后序布遍历的遍历顺序是左子树-右子树-根。所以我们仍然要先访问左子树。我们仍然要先访问左先把所有的左节点插入到栈里面。这一步其实和前面的中序遍历与前序遍历的思路是一样的但是在后序遍历里面是否能够访问当前节点是要做判断的当前节点必须在右节点被访问以后才能访问。 代码如下 class Solution { public:vectorint postorderTraversal(TreeNode* root) {stackTreeNode*st;vectorintret;TreeNode*cur root;TreeNode*prev nullptr;//记录前面访问了那一个节点while(!st.empty()||cur){while(cur)//只插入不访问{st.push(cur);cur cur-left;}TreeNode* top st.top();//找到最后一个插入栈的节点if(prev top-right)//如果这个节点的右节点已经被访问过来这个节点便是可以访问的{prev top;//更新prevret.push_back(top-val);st.pop();}else//如果这个节点的右节点没有被访问过便先访问右节点右树{cur top-right;prev cur;//更新prev}}return ret;} };
http://www.w-s-a.com/news/178081/

相关文章:

  • 王店镇建设中心小学网站酷玛网站建设
  • 网站需求方案wordpress博客主题推荐
  • 网站安全证书过期怎么办那个视频网站最好最全网址
  • 外贸上哪个网站开发客户建行个人网上银行登录入口
  • 空间除了可以做网站还能干什么qq钓鱼网站
  • 网站 技术企业网站用免费程序
  • 做网站的中文名字汕尾网站开发
  • 网站推广效果推广网站推荐
  • 腾讯企业网站建设网络推广比较经典和常用的方法有
  • 四川成都网站网页设计上海外贸网站制作公司
  • wordpress模板首页图片锦州网站做优化
  • 哔哩哔哩网站建设分析有哪些做网站好的公司
  • 福建建设执业中心网站沧州网络推广外包公司
  • 做网站怎么改关键词营销网站建设818gx
  • 广撒网网站怎么进行网络营销
  • 中职计算机网站建设教学计划电商网站如何避免客户信息泄露
  • 惠州微网站建设外贸进出口代理公司
  • 网站建设最常见的问题建设银行网站机构
  • 网站集群建设相关的招标南通seo网站建设费用
  • 网络培训的网站建设能够做二维码网站
  • 网站类游戏网站开发wordpress 文章首标点
  • 徐州网站建设熊掌号免费推广网站入口2020
  • 网站建设有前途长春高铁站
  • 做网站网课阿里云域名查询系统
  • saas建站平台有哪些简述网站建设基本流程答案
  • 个人怎么做网站网站浏览思路
  • 网站建设里的知识长沙网络营销公司
  • 网站建设与维护大作业pc网站转换成微网站
  • php网站开发经典教材东莞网站开发
  • 教育培训手机网站模板下载跨境电商培训哪家最好