数据结构:二叉树OJ题(基础版)

前言

更完两期二叉树的知识之后,来做几道oj题巩固一下基础


一、翻转二叉树

链接:leetcode链接

在这里插入图片描述

还是分治思想,将问题分解成左子树和右子树交换,遇到空树停止

采用递归算法做题

 TreeNode* invertTree(TreeNode* root) {
        if(root == nullptr)
        return nullptr;

        swap(root->left,root->right);

        invertTree(root->left);
        invertTree(root->right);

        return root;
    }

二、另一棵树的子树

链接:leetcode链接

在这里插入图片描述
我们可以分解子问题,是不是当前树的子树,是不是左子树的子树,是不是右子树的子树。

细节:如果不是当前树的子树,不应该返回false,而应该继续在左右子树寻找


bool isSame(TreeNode* a,TreeNode* b)
    {
        if(a == nullptr && b == nullptr)
        return true;

        if(a == nullptr || b == nullptr)
        return false;

        if(a->val != b->val)
        return false;

        return isSame(a->left,b->left)
            && isSame(a->right,b->right);
    }

    bool isSubtree(TreeNode* root, TreeNode* subRoot) {
        if(root == nullptr)
        return false;

        if(root->val == subRoot->val)
        {
            bool ret = isSame(root,subRoot);
            if(ret) return true;
        }

        return isSubtree(root->left,subRoot)
            || isSubtree(root->right,subRoot);
    }

三、二叉树的构建及遍历

链接:牛客链接

在这里插入图片描述

思路:
中序遍历很简单,很容易实现
这里,比较难的地方是,如何从先序遍历的序列中构建出二叉树
ok,我的思路是这样的:
先去构建当前树,再去构建左子树,再去构建右子树,符合先序遍历的顺序
很明显,这又是一个递归算法。
那么核心就是如何构建好当前树
遇到‘#’,就代表遇到空节点,遇到其他字符,就正常构建
注意:要传参控制string的下标,不然,没办法结束。

#include <iostream>
using namespace std;


struct TreeNode
{
    TreeNode* left = nullptr;
    TreeNode* right = nullptr;
    char val;
};


TreeNode* Creater(string& s,int& i)
{
    TreeNode* root = new TreeNode;
    if(s[i] == '#')
    {
    i++;
    return nullptr;
    }

    root->val = s[i++];

    root->left = Creater(s, i);
    root->right = Creater(s, i);

    return root;
}

void InOrder(TreeNode* root)
{
    if(root == nullptr)
    return ;

    InOrder(root->left);
    cout << root->val << " ";
    InOrder(root->right);
}

int main() {
   string s;
   cin >> s;
   int i = 0;
   TreeNode* root = Creater(s,i);
   InOrder(root);
   cout << endl;
   return 0;
}

四、对称二叉树链接:

链接:leetcode链接

在这里插入图片描述

思路:我们这样想,如何比较两棵树是否对称呢?
记为root_a树和root_b树
显然,需要
(1) root_a树的根节点与root_b树的根节点值相等
(2) 需要root_a树的左子树和root_b树的右子树相等
(3) 需要root_a树的右子树和root_b树的左子树相等
空树为最小子问题

 bool isMirror(TreeNode* left, TreeNode* right) {
       if(left == nullptr && right == nullptr)
       return true;

       if(left == nullptr || right == nullptr)
       return false;

       if(left->val != right->val)
       return false;

       return isMirror(left->left,right->right)
           && isMirror(left->right,right->left);
    }

    bool isSymmetric(TreeNode* root) {
        if (root == nullptr)
            return true;

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

五、层序遍历

链接:leetcode链接

在这里插入图片描述
注意:该题目不仅仅是层序遍历,另外要求将每一层分开输出。
核心点在于,如何在层序遍历时区分二叉树每一层

层序遍历时的规律:
用队列存储节点,
可以发现,每次出完一层之后,
恰好下一层的所有节点正好进入队列
也就是队列中剩余元素的个数就是下一层的节点的个数
(读者可尝试自己画图分析)

依照次规律,我们可以另外设置一个变量,来记录每一层需要输出的个数。

vector<vector<int>> levelOrder(TreeNode* root) {
        queue<TreeNode*> q;
        if(root == nullptr)
        return {};
        vector<vector<int>> vv;
        q.push(root);
        
        int levelSize = 1;

        while(!q.empty())
        {
            vector<int> v;
            while(levelSize--)
            {
            TreeNode* front = q.front();
            q.pop();
            v.push_back(front->val);

            if(front->left)  q.push(front->left);
            if(front->right) q.push(front->right);
            }

            levelSize = q.size();
            vv.push_back(v);
        }

        return vv;
    }

六、判断是不是完全二叉树

链接:牛客链接

在这里插入图片描述

思路:
根据完全二叉树层序遍历的规律
出完上一层的同时,下一层全部进入队列
所以,我们可以这么操作
我们不管出队列的节点的左节点和右节点是否为nullptr,都进入队列。
当我们出到nullptr的时候,我们就跳出循环
去检查队列中剩余的元素
如果有非空元素,则并不是完全二叉树,如果全部都是空,则是完全二叉树。

为什么可以这么操作呢?
当我们出到nullptr的时候,如果后面有非空节点,那么他一定是nullptr节点前面节点的子节点,他一定进入了队列。
(这点理解清楚,这道题目就没问题了,读者可以画图尝试理解)

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

        while(!q.empty())
        {
            TreeNode* front = q.front();
            q.pop();

            if(front != nullptr)
            {
                q.push(front->left);
                q.push(front->right);
            }
            else break;
        }

        while(!q.empty())
        {
            TreeNode* front = q.front();
            if(front != nullptr)
            return false;
            q.pop();
        }

        return true;
    }

ok,先讲着6个题目吧,后面更复杂的题目,会在后续博客中进行更新

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Golang | Leetcode Golang题解之第409题最长回文串

题目&#xff1a; 题解&#xff1a; func longestPalindrome(s string) int {mp : map[byte]int{}for i : 0; i < len(s); i {mp[s[i]]}res : 0for _, v : range mp {if v&1 1 {res v - 1} else {res v}}if res<len(s) {res}return res }

华为HarmonyOS地图服务 3 - 如何开启和展示“我的位置”?

一. 场景介绍 本章节将向您介绍如何开启和展示“我的位置”功能&#xff0c;“我的位置”指的是进入地图后点击“我的位置”显示当前位置点的功能。效果如下&#xff1a; 二. 接口说明 “我的位置”功能主要由MapComponentController的方法实现&#xff0c;更多接口及使用方法…

基于51单片机的手环设计仿真

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 基于STC89C52单片机&#xff0c;DHT11温湿度采集温湿度&#xff0c;滑动变阻器连接ADC0832数模转换器模拟水位传感器检测水位&#xff0c;通过LCD1602显示信息&#xff0c;然后在程序里设置好是否…

JavaEE: 创造无限连接——网络编程中的套接字

文章目录 Socket套接字TCP和UDP的区别有连接/无连接可靠传输/不可靠传输面向字节流/面向数据报全双工/半双工 UDP/TCP api的使用UDPDatagramSocketDatagramPacketInetSocketAddress练习 TCPServerSocketSocket练习 Socket套接字 Socket是计算机网络中的一种通信机制&#xff0…

代码随想录算法训练营第五十八天 | 拓扑排序精讲-软件构建

目录 软件构建 思路 拓扑排序的背景 拓扑排序的思路 模拟过程 判断有环 写代码 方法一&#xff1a; 拓扑排序 软件构建 题目链接&#xff1a;卡码网&#xff1a;117. 软件构建 文章讲解&#xff1a;代码随想录 某个大型软件项目的构建系统拥有 N 个文件&#xff0c;文…

机器人的动力学——牛顿欧拉,拉格朗日,凯恩

机器人的动力学推导方法有很多&#xff0c;常用得有牛顿&#xff0c;拉格朗日&#xff0c;凯恩等方法&#xff0c;接下来&#xff0c;简单说说他们之间的使用。注&#xff1a;这里不考虑怎么来的&#xff0c;只说怎么应用。 参考1&#xff1a;4-14动力学分析方法-牛顿—欧拉方…

聚焦API安全未来,F5打造无缝集成的解决方案

研究发现&#xff0c;目前超过90%的基于Web的网络攻击都以API端点为目标。随着对API使用需求的增加&#xff0c;这些攻击还会持续增长。现代企业需要一种动态防御策略&#xff0c;在风险升级成代价高昂、令人警惕且往往无法预防的API安全漏洞之前&#xff0c;发现并降低风险。 …

数据库提权【笔记总结】

文章目录 UDF提权以有webshell只有数据库权限条件复现msf工具sql语句提权 MOF提权前言条件复现msf工具php脚本提权 sqlserver提权前言条件xp_cmdshell提权复现 沙盒提权介绍复现 Oracle提权靶场搭建执行任意命令复现 通过注入存储过程提权&#xff08;低权限提升至DBA&#xff…

C++从入门到起飞之——多态 全方位剖析!

&#x1f308;个人主页&#xff1a;秋风起&#xff0c;再归来~&#x1f525;系列专栏&#xff1a;C从入门到起飞 &#x1f516;克心守己&#xff0c;律己则安 目录 1. 多态的概念 2. 多态的定义及实现 2.1 多态的构成条件 2.1.1 实现多态还有两个必须重要条件&…

群晖NAS使用Docker本地部署网页版Ubuntu系统并实现无公网IP远程访问

文章目录 前言1. 下载Docker-Webtop镜像2. 运行Docker-Webtop镜像3. 本地访问网页版Linux系统4. 群晖NAS安装Cpolar工具5. 配置异地访问Linux系统6. 异地远程访问Linux系统7. 固定异地访问的公网地址 前言 本文旨在详细介绍如何在群晖NAS部署docker-webtop&#xff0c;并结合c…

通用接口开放平台设计与实现——(31)API服务线程安全问题确认与修复

背景 在本系列的前面一篇博客评论中&#xff0c;有小伙伴指出&#xff0c;API服务存在线程安全问题&#xff1a; https://blog.csdn.net/seawaving/article/details/122905199#comments_34477405 今天来确认下&#xff0c;线程是否安全&#xff1f;如不安全&#xff0c;如何…

高配小主机加装SSD固态硬盘,我选择性能与设计兼备的希捷酷鱼 530

高配小主机加装SSD固态硬盘&#xff0c;我选择性能与设计兼备的希捷酷鱼 530 哈喽小伙伴们好&#xff0c;我是Stark-C~ 我最近入手了零刻的一款新发布的 GTi12 Ultra高性能迷你主机&#xff0c;其出色的配置与强大的功能让我有了将它用作主力机的打算。不过因为它的高配版本搭…

【记录一下VMware上开虚拟端口映射到公网】

材料 win11 和装在vmware上的ubuntu 步骤一在Ubuntu上配置静态地址&#xff0c;配置如下 vim /etc/netplan/01-network-manager-all.yaml(此文件看系统上对应的是哪个文件&#xff0c;建议先备份)network:version: 2renderer: NetworkManagerethernets:ens33:dhcp4: falseadd…

四十一、完成内容添加功能(使用go测试方法)

目录 一、添加model 二、完成相关dao 三、使用测试类进行测试 1、把光标防止要测试的方法上&#xff0c;右击并选择 2、自动会生成一个以dao文件加_test命名的文件 3、在其中完善方法并完成测试 四、完成content_create_handle 一、添加model 按数据库字段以及字段格式完…

Android 如何实现搜索功能:本地搜索?数据模型如何设计?数据如何展示和保存?

目录 效果图为什么需要搜索功能如何设计搜索本地的功能&#xff0c;如何维护呢&#xff1f;总结 一、效果图 二、为什么需要搜索功能 找一个选项&#xff0c;需要花非常多的时间&#xff0c;并且每次都需要指导客户在哪里&#xff0c;现在只要让他们搜索一下就可以。这也是模…

基于SpringBoot+Vue的剧本杀管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 【2025最新】基于JavaSpringBootVueMySQL的…

AIGC7: 高通骁龙AIPC开发者沙龙过程记录A

图中是一座高耸的宫殿。 就像AI的出现&#xff0c;慢慢初现端倪&#xff0c;头角峥嵘。 背景 一直以来都比较关注AI的发展&#xff0c;有幸再一次参加异常AI的盛会。 从我的角度看。 高通是一家生产芯片的公司&#xff0c;国内的小米&#xff0c;荣耀&#xff0c;Oppo , Vi…

华为为什么要做三折叠屏手机?

前些天我做了一条视频&#xff0c;关于讲华W的新的三折叠屏手机。我说我有点失望&#xff0c;结果引起了华W的同事的一些关注。于是&#xff0c;华W几位高管都跑过来&#xff0c;跟我解释为什么会出现这样的一个状态。 我才知道&#xff0c;这款手机他们其实是亏着钱在卖的。因…

【测试】——Selenium API (万字详解)

&#x1f4d6; 前言&#xff1a;本文详细介绍了如何利用Selenium进行Web自动化测试&#xff0c;包括定位元素&#xff08;如cssSelector和xpath&#xff09;、常用操作函数&#xff08;如点击、输入等&#xff09;、窗口管理、键盘鼠标事件和浏览器导航&#xff0c;以及处理弹窗…

图说GPT网络结构(参数量与计算量估计)

现在AI领域的主流模型几乎都是Transformer网络架构衍生而来。大热的LLM中的生成类模型很多都是来自于Transformer的变体&#xff0c;即decoder only架构。而GPT就是该类中的经典模型。尽管现在变体甚多&#xff0c;但大多没有根本性地改变其套路。 为了阐述方便&#xff0c;首…