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

深圳定制家具哪家性价比高襄阳网站seo

深圳定制家具哪家性价比高,襄阳网站seo,seo优化工作内容,网站的优化承诺文章目录1. 二叉树的镜像2. 判断是不是完全二叉树3. 完全二叉树的节点个数4. 判断是不是平衡二叉树1. 二叉树的镜像 #include <ctime> class Solution {public:TreeNode* Mirror(TreeNode* pRoot) {// write code hereif (pRoot nullptr) return pRoot;//这里记得要记得…

文章目录

    • 1. 二叉树的镜像
    • 2. 判断是不是完全二叉树
    • 3. 完全二叉树的节点个数
    • 4. 判断是不是平衡二叉树

1. 二叉树的镜像

在这里插入图片描述

#include <ctime>
class Solution {public:TreeNode* Mirror(TreeNode* pRoot) {// write code hereif (pRoot == nullptr) return pRoot;//这里记得要记得保存pRoot->left,否则就会被pRoot->right覆盖TreeNode* node = pRoot->left;pRoot->left = Mirror(pRoot->right);pRoot->right = Mirror(node);return pRoot;}
};

2. 判断是不是完全二叉树

在这里插入图片描述

  • 先判断空树一定是完全二叉树。
  • 初始化一个队列辅助层次遍历,将根节点加入。
  • 逐渐从队列中弹出元素访问节点,如果遇到某个节点为空,进行标记,代表到了完全二叉树的最下层,若是后续还有访问,则说明提前出现了叶子节点,不符合完全二叉树的性质。
  • 否则,继续加入左右子节点进入队列排队,等待访问。
/*** struct TreeNode {*  int val;*  struct TreeNode *left;*  struct TreeNode *right;*  TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* };*/
class Solution {public:bool isCompleteTree(TreeNode* root) {// write code hereif (root == nullptr) return true;queue<TreeNode*> que;que.push(root);bool flag = false;while (!que.empty()) {int size = que.size();for (int i = 0; i < size; ++i) {TreeNode* node = que.front();que.pop();if(node == nullptr){flag = true;}else{if(flag) return false;que.push(node->left);que.push(node->right);}}}return true;}
};

3. 完全二叉树的节点个数

在这里插入图片描述
在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第 h 层,则该层包含 1~ 2^(h-1) 个节点。

完全二叉树只有两种情况

  • 情况一:就是满二叉树,可以直接用 2^树深度 - 1 来计算,注意这里根节点深度为1。
  • 情况二:最后一层叶子节点没有满,分别递归左孩子,和右孩子,递归到某一深度一定会有左孩子或者右孩子为满二叉树,然后依然可以按照情况1来计算。
class Solution {
public:int countNodes(TreeNode* root) {if(root == nullptr){return 0;}TreeNode* left = root->left;TreeNode* right = root->right;int leftd = 0;int rightd = 0;while(left != nullptr){left = left->left;leftd++;}while(right != nullptr){right = right->right;rightd++;}if(leftd == rightd){return (2 << leftd) - 1;}return countNodes(root->left) + countNodes(root->right) + 1;}
};

4. 判断是不是平衡二叉树

在这里插入图片描述
分别求出其左右子树的高度,然后如果差值小于等于1,则返回当前二叉树的高度,否则返回-1,表示已经不是二叉平衡树了。

class Solution {
public:bool IsBalanced_Solution(TreeNode* pRoot) {if(pRoot == nullptr) return true;int result = getHigh(pRoot);return result == -1 ? false : true;}
private:int getHigh(TreeNode* root){if(root == nullptr) return 0;int left = getHigh(root->left);if(left == -1) return -1;int right = getHigh(root->right);if(right == -1) return -1;return abs(left - right) > 1 ? -1 : 1 + max(left, right);}
};
http://www.hkea.cn/news/508018/

相关文章:

  • 做网站 博客百度推广助手客户端
  • 温州市手机网站制作哪家好爱站网长尾词挖掘
  • 党委网站建设要求凡科建站靠谱吗
  • wordpress 安卓客户端福建seo优化
  • 襄阳seo技术长沙seo网站优化
  • 做一的同志小说网站做seo要投入什么
  • 网站的文件结构百度搜索排名怎么收费
  • 全景网站app网络营销工具分析
  • 南京建设工程交易中心网站seo是什么的简称
  • 利用vps做网站关键字排名查询
  • 常熟网站制作找哪家好品牌型网站制作价格
  • 怎么做自己网站推广网络广告
  • 化州网站建设促销方法100种
  • 长沙专业网站设计平台新闻最新消息10条
  • 惠州网站建设制作宣传推广方案
  • 宁波网站推广外包服务长岭网站优化公司
  • 哈尔滨市哪里做淘宝网站seo课程心得体会
  • 做网站建设公司企业一个企业该如何进行网络营销
  • 移动端h5网站开发服务企业seo推广
  • 管理公司网站建设引擎搜索优化
  • 上市公司专利查询网站百度广告投放价格
  • html5电商网页制作网站怎么seo关键词排名优化推广
  • 大同网站建设黄冈网站推广优化找哪家
  • 昌邑网站建设站长之家网站排名
  • 建设企业网站的需求分析免费域名
  • 重庆欧勒精细有限公司网站策划书百度竞价推广开户
  • 怎么做一键添加信任网站ios aso优化工具
  • ps做网站的分辨率多少钱苹果cms永久免费建站程序
  • 网站推广积分常用于网站推广的营销手段是
  • wordpress时间云储存沈阳网站制作优化推广