hot100 -- 二叉树(上)

news2025/1/11 22:51:50

目录

🎂二叉树的中序遍历

AC  递归

AC  迭代

🌼二叉树的最大深度

AC  DFS递归

AC  BFS

🚩翻转二叉树

AC  后序(递归)

AC  中序

🚩对称二叉树

AC  递归

AC  迭代

🌼二叉树的直径

AC  递归

🎂二叉树的层序遍历

AC  BFS


🎂二叉树的中序遍历

94. 二叉树的中序遍历 - 力扣(LeetCode)

详细介绍👇

树,二叉树,二叉树遍历,哈夫曼树(详解+刷题)_哈夫曼树前置知识点-CSDN博客

AC  递归

时间 O(n) -- 每个节点只被遍历 1 次;空间 O(n) -- 递归栈,一条链时,最大深度 n

/**
 * 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:
    void inorder(TreeNode* root, vector<int> &ans) {
        if (!root) return;
        inorder(root->left, ans); // 左
        ans.push_back(root->val); // 根
        inorder(root->right, ans); // 右
    }

    vector<int> inorderTraversal(TreeNode* root) { // 不要改给定的接口
        vector<int> res;
        inorder(root, res);
        return res;
    }
};

AC  迭代

栈模拟中序遍历,先遍历到左子树最深处,然后依次遍历栈顶每个节点的右子树

(根也是遍历左子树的一部分)

时间 O(n),空间 O(n)

/**
 * 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> ans;

        // 栈模拟中序遍历
        stack<TreeNode*> stk; // 存的是节点(指针)
        while (root || !stk.empty()) {
            // 遍历到左子树最深处
            while (root) {
                // 先遍历的加入栈底,最深处在栈顶
                stk.push(root); // 节点入栈
                root = root->left;
            }
            root = stk.top();
            stk.pop();
            ans.push_back(root->val);
            // 左子树遍历完,到右子树
            root = root->right;
        }
        return ans;
    }
};

🌼二叉树的最大深度

104. 二叉树的最大深度 - 力扣(LeetCode)

AC  DFS递归

时间 O(n);空间 O(height) -- 二叉树高度,即递归栈的深度

/**
 * 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:
    int maxDepth(TreeNode* root) {
        if (!root) return 0;
        return 1 + max(maxDepth(root->left), maxDepth(root->right));
    }
};

AC  BFS

时间 O(n),空间 O(n) 

/**
 * 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:
    queue<TreeNode*> q;
    int maxDepth(TreeNode* root) {

        if (!root) return 0;
        q.push(root);

        int ans = 0; 
        while (!q.empty()) {
            ans++; // 深度 +1
            int sz = q.size();
            // 拓展当前层所有节点
            while (sz--) {
                TreeNode* node = q.front(); q.pop(); // queue 是 front()
                if (node->left) q.push(node->left);
                if (node->right) q.push(node->right);
            }
        }
        return ans;
    }
};

🚩翻转二叉树

226. 翻转二叉树 - 力扣(LeetCode)

AC  后序(递归)

根节点 -> 递归左子树 -> 递归右子树(由于只是“左右翻转”,本题不需处理根节点)

/**
 * 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:
    TreeNode* invertTree(TreeNode* root) {
        if (!root) return nullptr; // 递归出口

        TreeNode* right = invertTree(root->right); // 递归右子树
        TreeNode* left = invertTree(root->left); // 递归左子树

        // 回溯--交换当前节点的左右
        root->left = right;
        root->right = left; 

        return root;
    }
};

AC  中序

/**
 * 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:
    TreeNode* invertTree(TreeNode* root) {
        if (!root) return nullptr; // 递归出口

        TreeNode* left = invertTree(root->left); // 递归左子树

        // 回溯 -- 交换左右
        TreeNode* rightNode = root->right;
        root->right = root->left;
        root->left = rightNode;

        // 此时的 root->left 即原来的右子树
        TreeNode* right = invertTree(root->left); // 递归右子树

        return root;
    }
};

🚩对称二叉树

101. 对称二叉树 - 力扣(LeetCode)

AC  递归

在根节点中间,画一条对称的虚线,左边,右边,看作独立的两棵树,那么问题可以转化为

什么条件下,左右两颗树是对称的呢

1)两个根节点->val 相等(2 == 2)

2)左子树的右子树->val == 右子树的左子树->val(4 == 4)

3)左子树的左子树->val == 右子树的右子树->val(3 == 3)

时空 O(n) 

/**
 * 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:
    bool isSame(TreeNode* l, TreeNode* r) {
        if (!l && !r) return true; // 2个空
        if (!l || !r) return false; // 1个空

        // 3 个 &&,保证每一对节点都对称,才为 true
        // 但凡出现一次 false,结果就是 false
        bool ans = (l->val == r->val) && isSame(l->right, r->left)
                                      && isSame(l->left, r->right);
        return ans;
    }
    bool isSymmetric(TreeNode* root) {
        if (!root) return true; // 递归出口

        return isSame(root->left, root->right);
    }
};

AC  迭代

用 BFS 进行迭代,队列实现 BFS,详细解析 BFS👇

《啊哈算法第四章之bfs》(17张图解)_图解bfs算法-CSDN博客

时空 O(n)

/**
 * 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:
    bool isSymmetric(TreeNode* root) {
        queue<TreeNode*> q; // 队列实现 BFS
        TreeNode *u = root, *v = root;
        q.push(u); q.push(v);

        // bfs 一层一层拓展
        while (!q.empty()) {
            // 取两个对称节点
            u = q.front(); q.pop();
            v = q.front(); q.pop();

            // 2个空(对称)
            if (!u && !v) continue; 
            // 1个空 或 值不同(不对称)
            if ( (!u || !v) || (u->val != v->val) ) return false;

            // 此时当前节点 u, v 是对称的,可以继续拓展
            // 按顺序加入两组节点
            q.push(u->left); q.push(v->right);
            q.push(u->right); q.push(v->left);
        }
        return true;
    }
};

🌼二叉树的直径

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

AC  递归

不要直接对每个节点,调用一次遍历二叉树最大深度的 maxDepth(),这样时间 O(n^2),而是在 maxDepth() 中,动态更新 ans,当然,maxDepth() 的返回值还是最大深度

时空 O(n)

/**
 * 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:
    int ans = 0;

    int maxDepth(TreeNode* root) { // 返回最大深度
        if (!root) return 0; // 递归出口
        
        // 递归
        int L = maxDepth(root->left);
        int R = maxDepth(root->right);

        // 不用 -2,因为L,R都是从子树开始的
        ans = max(ans, L + R); // 边递归边得到结果

        return 1 + max(L, R);
    }

    int diameterOfBinaryTree(TreeNode* root) {
        maxDepth(root);
        return ans;
    }
};

🎂二叉树的层序遍历

102. 二叉树的层序遍历 - 力扣(LeetCode)

AC  BFS

关于 vector 的 .back() 👇

std::vector - cppreference.com

std::vector<T,Allocator>::back - cppreference.com

-- 第33,34行

q.push(temp->left) 和 q.push(temp->right) 前,要先判断 左 / 右 子树存在,否则就会插入空指针 null pointer

时空 O(n)

/**
 * 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:
    // 队列实现BFS--层序遍历
    vector<vector<int>> levelOrder(TreeNode* root) {

        vector< vector<int> > ans;
        if (!root) return ans;

        queue<TreeNode*> q;
        q.push(root);

        // 一层一层拓展
        while (!q.empty()) {
            // vector<int>() 调用构造函数,创建一个空的 vector 对象
            ans.push_back(vector<int>());
            int size = q.size(); // 当前层节点数

            // 拓展当前层
            for (int i = 0; i < size; ++i) {
                TreeNode* temp = q.front(); q.pop(); // 取队头
                ans.back().push_back(temp->val); // 插入值 val
                if (temp->left) q.push(temp->left);
                if (temp->right) q.push(temp->right);
            }
        }
        return ans;
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1640036.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言之位操作符:<<、>>、、|、^、~,以及原码反码补码和例题详解

目录 前言 一、原码、反码、补码 二、移位操作符 三、位操作符&#xff1a;&、|、^、~ 四、经典例题分析&#xff1a; 总结 前言 本文将详细介绍C语言中左移操作符<<&#xff0c;右移操作符>>&#xff0c;按位与&&#xff0c;按位或|&#xff0c;按位异或^…

VS(Visual Studio)中查找项目里的中文字符

目录 正则表达式查找中文字符 正则表达式查找中文字符 在Visual Studio (VS) 中查找所有的中文字符&#xff0c;你可以使用其强大的查找和替换功能。不过&#xff0c;由于中文字符的范围非常广泛&#xff08;包括简体中文、繁体中文、日本汉字、韩国汉字等&#xff09;&#xf…

C语言——小知识和小细节17

一、未能给指针成功赋值 #include <stdio.h> #include <stdlib.h> #include <string.h>void GetMemory(char* p) {p (char*)malloc(20 * sizeof(char)); }void Test() {char* str NULL;GetMemory(str);strcpy(str, "Hello World!");printf(&quo…

计算机网络chapter2——应用层

文章目录 第2章 应用层章节引出—— 2.1应用层协议原理2.1.1 网络应用程序体系结构&#xff08;1&#xff09;客户-服务器体系结构&#xff08;2&#xff09;对等(P2P)体系结构2.1.2 进程通信1.客户和服务器进程2.进程与计算机网络之间的接口3. 进程寻址 2.1.3 可供应用程序使用…

Linux shell编程学习笔记48:touch命令

0 前言 touch是csdn技能树Linux基础练习题中最常见的一条命令&#xff0c;这次我们就来研究它的功能和用法。 1. touch命令的功能、格式和选项说明 我们可以使用命令 touch --help 来查看touch命令的帮助信息。 purpleEndurer bash ~ $ touch --help Usage: touch [OPTION]…

双指针(C++)

文章目录 1、移动零2、复写零3、快乐数4、盛最多水的容器5、有效三角形的个数6、和为s的两个数7、三数之和8、四数之和 需要理解的是&#xff0c;双指针并非只有指针&#xff0c;双指针的意思是两个位置。比如对于数组来说&#xff0c;两个下标也是双指针。当然&#xff0c;也可…

基础IO认识

回顾文件 我们之前认识文件只是在语言程度上理解&#xff0c;但是我们理解的不够彻底&#xff0c;要想真正理解文件要在os上理解。 简单代码认识 1 #include<stdio.h>2 int main(){3 FILE* fpfopen("log.txt","w");4 if(fpNULL){5 p…

【小浩算法 BST与其验证】

BST与其验证 前言我的思路思路一 中序遍历判断数组无重复递增思路二 递归边界最大值最小值的传递 我的代码测试用例1测试用例2 前言 BST是二叉树一个经典应用&#xff0c;我们常常将其用于数据的查找以及构建平衡二叉树等。今天我所做的题目是验证一颗二叉树是否为二叉搜索树&…

Web,Sip,Rtsp,Rtmp,WebRtc,专业MCU融屏视频混流会议直播方案分析

随着万物互联&#xff0c;视频会议直播互动深入业务各方面&#xff0c;主流SFU并不适合管理&#xff0c;很多业务需要各种监控终端&#xff0c;互动SIP硬件设备&#xff0c;Web在线业务平台能相互融合&#xff0c;互联互通&#xff0c; 视频混流直播&#xff0c;录存直播推广&a…

带环链表问题

带环链表就是字面意思带环的链表&#xff0c;例如以下这三种情况 练习题 1.给定一个链表&#xff0c;判断链表中是否带环. - 力扣&#xff08;LeetCode&#xff09; 思路&#xff1a;快慢指针&#xff0c;慢指针走一步&#xff0c;快指针走两步&#xff0c;两个指针从链表的起…

硅片和SOI哪个研究方向更好?

知识星球&#xff08;星球名&#xff1a;芯片制造与封测社区&#xff0c;星球号&#xff1a;63559049&#xff09;里的学员问&#xff1a;我研一将要结束&#xff0c;即将进入课题组。我们课题组方向有硅片和soi两种方向&#xff0c;这两种方向该如何选择呢&#xff1f; 硅片与…

python离线安装包的方法

python离线安装包的方法 访问对应安装包的镜像文件的网站找到适合自己的whl文件安装 访问对应安装包的镜像文件的网站 https://mirrors.tuna.tsinghua.edu.cn/pypi/web/simple/<包名>/找到适合自己的whl文件 安装 下载完成后&#xff0c;进入opencv_python-3.4.11.45-c…

这是一个简单网站,后续还会更新

1、首页效果图 代码 <!DOCTYPE html> <html> <head> <meta charset"utf-8" /> <title>爱德照明网站首页</title> <style> /*外部样式*/ charset "utf-8"…

标准降水指数(SPI)、标准化降水蒸发蒸腾指数(SPEI)和帕尔默干旱指数(PDSI)的下载、读取和可视化

数据下载网址&#xff1a;WWDT Data (dri.edu)https://wrcc.dri.edu/wwdt/data/PRISM/ 以SPI为例说明&#xff0c; 标准化降水指数(Standardized Precipitation Index, SPI)是由Mckee et al(.1993)分析美国科罗拉多干旱时,发现降水服从偏态分布,基于此提出了标准化降水指数。…

【千帆平台】使用AppBuilder三步手搓应用创建精准多轮对话agent之K12互动式练习题

欢迎来到《小5讲堂》 这是《千帆平台》系列文章&#xff0c;每篇文章将以博主理解的角度展开讲解。 温馨提示&#xff1a;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不对之处望指正&#xff01; 目录 前言创建应用应用头像应用名称应用描述角色指令能力扩展开场白 …

gitlab设置保护分支

gitlab设置保护分支方法 进入代码仓库首页&#xff0c;找到settings下的repository并点击进入 找到Protected Branches 下的Exoand按钮&#xff0c;并点击展开 可以看到已经存在默认的保护分支&#xff0c;通常是master/main分支&#xff0c;也可以添加新的保护分支 新建保护分…

使用idm下载百度云被限速 idm下载大文件后要整合 idm下载百度网盘有限制最新解决办法教程 idm限速解除方法

Internet Download Manager简称IDM,是一款Windows系统专业下载加速工具,IDM下载器支持多种类型文件下载,并能完美恢复各种中断的下载任务,是一款Windows平台下的多线程下载器&#xff0c;支持浏览器自动嗅探功能下载资源文件&#xff0c;包括视频、音频以及图片等类型文件&…

BUUCTF:Web 解析(一)

一、[极客大挑战 2019] EasySQL 点击链接进入靶场 登录页面&#xff0c;查看页面源代码发现没留注释 先输入 admin or 11# 提交看看&#xff08;根据题意猜测考察的 SQL 注入&#xff09; 显示 Flag 二、[极客大挑战 2019] Havefun 打开靶场 页面只有一只猫&#xff0c;打开…

区块链 | IPFS:Merkle DAG(进阶版)

&#x1f98a;原文&#xff1a;Merkle DAGs: Structuring Data for the Distributed Web &#x1f98a;写在前面&#xff1a;本文属于搬运博客&#xff0c;自己留存学习。 1 Merkle DAG 当我们在计算机上表示图时&#xff0c;必须通过提供节点和边的具体表示来编码我们的数据…

jenkins 部署springboot 项目

文章目录 持续集成指定tag发布 基于Jenkins拉取GitLab的SpringBoot代码进行构建发布到测试环境实现持续集成 基于Jenkins拉取GitLab指定发行版本的SpringBoot代码进行构建发布到生产环境实现CD实现持续部署 持续集成 为了让程序代码可以自动推送到测试环境基于Docker服务运行…