二叉树进阶leetcode

606. 根据二叉树创建字符串

要点:前序遍历,当左子树为空时,右结点有数字时要给左边加括号

class Solution {
public:
    string tree2str(TreeNode* root) {
        string s;//创建一个字符串
        if(root==nullptr)
        {
            return s;
        }
        s+=to_string(root->val);//保存当前结点,转换为字符串
        if(root->left)//左子树不为空,继续往左子树走
        {
            s+="(";
            s+=tree2str(root->left);
            s+=")";
        }
        else if(root->right)//当左子树为空右子树不为空
        {
            s+="()";
        }

        if(root->right)//遍历右边
        {
            s+="(";
            s+=tree2str(root->right);
            s+=")";
        }//不需要加()
        return s;

    }
};

102. 二叉树的层序遍历

层次遍历想到用队列将一层一层的数据存入在拿出来

class Solution {
public:
    vector<vector<int>> levelOrder(TreeNode* root) {
        vector<vector<int>> vv;
        queue<TreeNode*> q;
        if(root)
        {
            q.push(root);//存入第一个结点
        }
       
        while(!q.empty())//判空
        {
            vector<int> v;
            int lenght=q.size();
            for(size_t i = 0;i<lenght;i++)//用一个值去控制输出的层次
            {
            TreeNode* front = q.front();//将存入的数提取
            v.push_back(front->val);//给一维数组赋值
            q.pop();//弹出
            if(front->left)//当有左值存入
                q.push(front->left);


            if(front->right)//当有右值存入
                q.push(front->right);
            
            }
           vv.push_back(v);//将该一维数组存入,二维数组中
        }
         return vv;
    }
};

107. 二叉树的层序遍历 II

和上一道题相反,只需要将结果反转最后的二维数组就可以了reverse(开始的迭代器和结束的迭代器)

class Solution {
public:
    vector<vector<int>> levelOrderBottom(TreeNode* root)
    {
         vector<vector<int>> vv;
        queue<TreeNode*> q;
        if(root)
        {
            q.push(root);//存入第一个结点
        }
       
        while(!q.empty())//判空
        {
            vector<int> v;
            int lenght=q.size();
            for(size_t i = 0;i<lenght;i++)//用一个值去控制输出的层次
            {
            TreeNode* front = q.front();//将存入的数提取
            v.push_back(front->val);//给一维数组赋值
            q.pop();//弹出
            if(front->left)//当有左值存入
                q.push(front->left);


            if(front->right)//当有右值存入
                q.push(front->right);
            
            }
           vv.push_back(v);//将该一维数组存入,二维数组中
        }
        reverse(vv.begin(),vv.end());
         return vv;
    }
};

236. 二叉树的最近公共祖先

分析:这里是二叉搜索树只要知道左边和右边中间的就是公共祖先

class Solution {
public:
    bool Find(TreeNode* root, TreeNode* p)
    {
        if(root==nullptr)
           return false;
        
        
        return root==p||Find(root->left,p)||Find(root->right,p);
    }
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        if(root==NULL)
            return NULL;

        if(root==p||root==q)
            return root;
        
        bool pInleft,pInright,qInleft,qInright;//这里代表pq在左边还是右边
        pInleft=Find(root->left,p);//这里也是递归,寻找p在那边
        pInright=!pInleft;

        qInleft=Find(root->left,q);//这里也是递归,寻找q在那边
        qInright=!qInleft;

        if((pInleft && qInright)||((qInleft && pInright)))
        {
            return root;//当pq在左右两边时root就是祖先
        }
        if(qInleft && pInleft)//当pq都在左边
        {
            return lowestCommonAncestor(root->left,p,q);
        }

        if(qInright && pInright)//当pq都在右边
        {
            return lowestCommonAncestor(root->right,p,q);
        }
        return NULL;
    }
};

 

二叉搜索树与双向链表_牛客题霸_牛客网 (nowcoder.com)

class Solution {
public:
    void convertList(TreeNode* cur,TreeNode*& prev)//这里为什么要加&,递归到最后改变cur并没有改变所以要加&,才知道用同一个
	{
		if(cur==NULL)
		{
			return;
		}
		convertList(cur->left,prev);
		cur->left=prev;

		if(prev)
		   prev->right = cur;

		prev =cur;

		convertList(cur->right,prev);

	}
    TreeNode* Convert(TreeNode* pRootOfTree) 
	{
		TreeNode* prev = NULL;
		convertList(pRootOfTree,prev);

		TreeNode* head = pRootOfTree;
		while(head && head->left)
		{
			head=head->left;
		}
		return head;
    }
};

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

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

相关文章

LLM | GPT-NEOX论文详解

GPT-NEOX使用旋转位置编码。模型权重使用float16表示。最大序列长度为2048。 论文题目&#xff1a;2022.04.14_GPT-NeoX-20B: An Open-Source Autoregressive Language Model 论文地址&#xff1a;2204.06745.pdf (arxiv.org) 论文代码&#xff1a;EleutherAI/gpt-neox: An imp…

go语言基础 -- 文件操作

基础的文件操作方法 go里面的文件操作封装在os包里面的File结构体中&#xff0c;要用的时候最好去查下官方文档&#xff0c;这里介绍下基本的文件操作。 打开关闭文件 import("os" ) func main() {// Open返回*File指针&#xff0c;后续的操作都通过*File对象操作…

Unsupervised Learning of Monocular Depth Estimation and Visual Odometry 论文阅读

论文链接 Unsupervised Learning of Monocular Depth Estimation and Visual Odometry with Deep Feature Reconstruction 0. Abstract 尽管基于学习的方法在单视图深度估计和视觉里程计方面显示出有希望的结果&#xff0c;但大多数现有方法以监督方式处理任务。最近的单视图…

归并排序总结

1.归并排序 归并排序的步骤如下&#xff1a; ①枚举中点&#xff0c;将区间分为左右两段&#xff1b; ②对左右两段区间分别排序&#xff1b; 这个过程以递归的方式进行。 ③合并两段区间。 是一个模拟的过程。用两个指针分别指向左右区间&#xff0c;判断当前哪个数小&…

FPGA——三速自适应以太网设计(2)GMII与RGMII接口

FPGA——以太网设计&#xff08;2&#xff09;GMII与RGMII 基础知识&#xff08;1&#xff09;GMII&#xff08;2&#xff09;RGMII&#xff08;3&#xff09;IDDR GMII设计转RGMII接口跨时钟传输模块 基础知识 &#xff08;1&#xff09;GMII GMII:发送端时钟由MAC端提供 下…

k近邻分类算法实现(KNN)

KNN算法实现 最近要用到对 某些数据进行自动识别分类&#xff0c;简单学习了一下k近邻算法&#xff0c;分享一下。 例如&#xff1a;电影动作片爱情片分类识别 这里我们使用了sklearn库&#xff0c;它用起来简单方便。 先提供代码如下&#xff1a; import numpy as np imp…

docker的简单使用

在一些进行使用靶场或者工具的时候&#xff0c;我们可以用docker在线拉取&#xff0c;就可以省去手动搭建靶场的过程 一、docker的配置 因为docker是默认从docker的官网进行拉取&#xff0c;所以拉取经常速度很慢或者失败&#xff0c;我们先要进行一下配置&#xff0c;让他优…

欧科云链:角力Web3.0,香港如何为合规设线?

在香港拥抱Web3.0的过程中,以欧科云链为代表的合规科技企业将凸显更大重要性。 ——据香港商报网报道 据香港明报、商报等媒体报道&#xff0c;港区全国政协兼香港选委界立法会议员吴杰庄在日前召开的全国两会上提出在大湾区建设国际中小企业创新Web3融资平台等提案&#xff0…

《系统架构设计师教程(第2版)》第6章-据库设计基础知识-01-数据库基本概念

文章目录 1. 概述1.1 基本概念1&#xff09;信息 (Information)2&#xff09;数据 (Data)3&#xff09;数据库 (DB)4&#xff09;数据库系统(DBS)5&#xff09;数据库管理系统&#xff08;DBMS&#xff09; 1.2 数据库技术的发展1.2.1 人工管理阶段1.2.2 文件系统阶段1&#xf…

C++中OpenMP的使用方法

适用场景 OpenMP是一种用于共享内存并行系统的多线程程序设计方案&#xff1b;简单地说&#xff0c;OpenMP通过一种较为简单的使用方式&#xff0c;实现代码的CPU并行化处理&#xff0c;从而最大化利用硬件的多核性能&#xff0c;成倍地提升处理效率&#xff1b; OpenMP适用场…

springboot3.x集成SpringDoc Swagger3

近期将springboox2.x升级到了3.x&#xff0c;索性将swagger2也同步升级到swagger3&#xff0c;具体过程如下。 一、添加maven依赖 <dependency><groupId>org.springdoc</groupId><artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>…

每日力扣——滑动窗口与前 K 个高频元素

&#x1f525; 个人主页: 黑洞晓威 &#x1f600;你不必等到非常厉害&#xff0c;才敢开始&#xff0c;你需要开始&#xff0c;才会变的非常厉害。 滑动窗口最大值 给定一个数组 nums&#xff0c;有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑…

uni app 微信小程序微信支付

使用方法 接口传参 使用wx.requestPayment方法是一个统一各平台的客户端支付API&#xff0c;不管是在某家小程序还是在App中&#xff0c;客户端均使用本API调用支付

STM32自学☞WDG(看门狗)及其案例

一、WDG简介 由于看门狗的代码很少所以就直接在main主函数中写了&#xff0c;没单独建文件 二、独立看门狗 涉及的按键可参考之前的key.c和key.h文件 独立看门狗配置流程&#xff1a; 1.开启时钟&#xff08;LSI&#xff09; 2.解除IWDG_PR和IWDG_RLR的写保护 3.写入预分频和重…

[HackMyVM]靶场 Wild

kali:192.168.56.104 主机发现 arp-scan -l # arp-scan -l Interface: eth0, type: EN10MB, MAC: 00:0c:29:d2:e0:49, IPv4: 192.168.56.104 Starting arp-scan 1.10.0 with 256 hosts (https://github.com/royhills/arp-scan) 192.168.56.1 0a:00:27:00:00:05 …

Golang的Channel源码阅读、工作流程分析。

Channel整体结构 源码位置 位于src/runtime下的chan.go中。 Channel整体结构图 图源&#xff1a;https://i6448038.github.io/2019/04/11/go-channel/ Channel结构体 type hchan struct {qcount uint // total data in the queuedataqsiz uint // si…

python unittest实现api自动化测试

这篇文章主要为大家详细介绍了python unittest实现api自动化测试的方法&#xff0c;具有一定的参考价值&#xff0c;感兴趣的小伙伴们可以参考一下 项目测试对于一个项目的重要性&#xff0c;大家应该都知道吧&#xff0c;写python的朋友&#xff0c;应该都写过自动化测试脚本…

Nginx启动服务

Nginx启动服务 一、启动前置 下载地址 如已安装Docker&#xff0c;下一步拉取Nginx最新的Docker镜像&#xff1a; docker pull nginx:latest查看拉取下来的镜像&#xff1a; docker images二、启动服务 创建Docker容器&#xff1a; docker run --name {projectname} -p 80…

Open3D 生成空间3D椭圆点云

目录 一、算法原理二、代码实现三、结果展示本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫与GPT。 一、算法原理 设椭圆在 X O Y XOY XO

MySQL基础-----SQL语句之DCL数据控制语句

目录 前言 一、管理用户 1.查询用户 2.创建用户 3.修改用户密码 4.删除用户 案例 二、权限控制 1.查询权限 2.授予权限 3.撤销权限 案例 前言 本期我们学习SQL语句的最后一部分内容&#xff0c;也就是数据控制语句DCL。DCL英文全称是Data Control Language(数据控制语…