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

台州网站建设网站推广公众号入口

台州网站建设网站推广,公众号入口,火锅料网站方案怎么做,外贸搜索推广简单 94.中序遍历 就说左子树-根-右子树顺序,之前也有二叉树相关的文章,基本上递归为主,这里用栈等方式实现下。 用到:栈 注意上面给出节点的基本结构,如左右,val指等 /*** Definition for a binary t…

简单

94.中序遍历

就说左子树-根-右子树顺序,之前也有二叉树相关的文章,基本上递归为主,这里用栈等方式实现下。

用到:栈

注意上面给出节点的基本结构,如左右,val指等

/*** 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:vector<int> inorderTraversal(TreeNode* root) {vector<int> res; //最后输出需要vector形式stack<TreeNode*> stk; //借助栈while(root||!stk.empty()){ while(root){  //塞满左边stk.push(root);root=root->left;}//往下翻存数,直到翻到右边root=stk.top();stk.pop();res.push_back(root->val);root=root->right;}return res;}
};

104.二叉树最大深度

递归即可,max(左子树深度,右子树深度)+1;

class Solution {
public:int maxDepth(TreeNode* root) {if(root==nullptr){return 0;}else{return max(maxDepth(root->left),maxDepth(root->right))+1;}}
};

 基于这道题,引申下面这道题:

二叉树的直径

543. 二叉树的直径 - 力扣(LeetCode)必须掌握上一题深度的写法,得到每个节点作为根节点的最大深度,同时记录其左右最大深度。

class Solution {
public:int max1=0;int Deep(TreeNode* root) {if(root==nullptr){return 0;}int left1= Deep(root->left);int right1=Deep(root->right);max1=max(max1,left1+right1);return max(left1,right1)+1;}int diameterOfBinaryTree(TreeNode* root) {if(root==nullptr){return 0;}Deep(root);return max1;}
};

226。翻转二叉树 

226.翻转二叉树

也是递归

class Solution {
public:TreeNode* invertTree(TreeNode* root) {if(root==nullptr){return nullptr;}TreeNode* left=invertTree(root->left);TreeNode* right=invertTree(root->right);root->left=right;root->right=left;return root;}
};

101.对称二叉树

要自己写个函数,再递归


class Solution {
public:
bool pan(TreeNode* t1,TreeNode* t2){ //自己写的函数if(t1==nullptr&&t2==nullptr){return true;}else if(t1==nullptr || t2==nullptr){return false;}else{return t1->val==t2->val &&pan(t1->left,t2->right)&&pan(t1->right,t2->left);}}bool isSymmetric(TreeNode* root) {//题目给的return pan(root,root);}
};

二叉树的直径 

543. 二叉树的直径 - 力扣(LeetCode)

中等

0927面试了某家中厂,考到二叉树层级遍历了,很悲催的没有做出来,在此反思复习一下。

树的递归——类似于图的深搜。

树的层级遍历——类似于图的广搜。

1.二叉树的层级遍历

. - 力扣(LeetCode)注意,这个q.size()是在不断变化的,if(current2->left/right)处理时,不断往q队列里塞入当前节点的左右节点,注意就不用else处理了。最后打印二维数组即可

借助数据结构:queue

class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {vector<vector<int>> result;if(!root){return result;}//为空处理queue<TreeNode*> q;q.push(root);while(!q.empty()){int levelSize=q.size();vector<int> current1;//层级for(int i=0;i<levelSize;++i){TreeNode *current2=q.front();//单个节点q.pop();current1.push_back(current2->val);if(current2->left){q.push(current2->left);}if(current2->right){q.push(current2->right);}        }
result.push_back(current1);   }return result;}
};

http://www.dtcms.com/a/552543.html

相关文章:

  • 福州哪里会网站制作的wordpress print_r
  • ps个人网站建设培训网址
  • 互联网网站 有哪些网站建设与网页设计论文
  • 重庆市住房和城乡建设厅网站门户网站开发设计方案
  • 网站关键词怎么填写哪家网络推广好
  • 青岛网页设计学校厦门seo网络推广
  • html5移动网站模板如何设置网站默认首页
  • 如何做企业网站界面app怎么做需要多少钱
  • 集运网站建设服务器安装wordpress
  • 成都网站建设 小兵cms网站建设的要点
  • 网站建设的利益昆明免费网站建设
  • 代做电大网站ui作业国内wordpress教程
  • 怎样用wordpress做网站下载网站模板怎么使用
  • 有建网站的软件兰州做网站优化的公司
  • 网站备案是备什么网站建设-信科网络
  • 网站专题页是什么微信crm系统哪家好
  • 企业 备案 网站服务内容百度百科分类方法
  • 济南企业建站哪家做的好网站主色调
  • 电子商务网站案例分析股东分红如何合理节税
  • 网站设计大全用python网站开发
  • 站点建错了网页能打开吗系统下载网站源码
  • 品牌做网站比较好的wordpress
  • 常见网站模式二季域名做网站
  • 哪些购物网站用php做的能用的网站
  • 老河口网站定制可以做翻译任务的网站
  • 在一家传媒公司做网站编辑 如何中国未来楼市走势分析
  • 哈尔滨模板建站推荐桂林网红民宿
  • 网站h1标签用在哪里建设网站纳什么税
  • 网站开发背景 目的青海培训网站建设公司
  • 彩票网站招代理广告怎么做企业网站的制作周期