【每日刷题】Day48

【每日刷题】Day48

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

1. 872. 叶子相似的树 - 力扣(LeetCode)

2. 114. 二叉树展开为链表 - 力扣(LeetCode)

1. 872. 叶子相似的树 - 力扣(LeetCode)

//思路:将两个二叉树的叶子节点分别存入两个数组中,使用memcmp函数比较两个数组中的内容是否相同从而判断两树是否叶子相似

bool IsLeafNode(struct TreeNode* root)

{

    return !root->left&&!root->right;

}


 

void GetLeafVal(struct TreeNode* root,int* arr,int* size)

{

    if(root==NULL)

    {

        return;

    }

    if(IsLeafNode(root))

    {

        arr[(*size)++] = root->val;

        return;

    }

    GetLeafVal(root->left,arr,size);

    GetLeafVal(root->right,arr,size);

}

bool leafSimilar(struct TreeNode* root1, struct TreeNode* root2)

{

    int arr1[200];

    int arr2[200];

    int size1 = 0;

    int size2 = 0;

    GetLeafVal(root1,arr1,&size1);

    GetLeafVal(root2,arr2,&size2);

    if(size1!=size2)

    {

        return false;

    }

    int ret = memcmp(arr1,arr2,sizeof(int)*size1);

    return ret==0;

}

2. 114. 二叉树展开为链表 - 力扣(LeetCode)

//思路:先序遍历二叉树,将每个结点的值存入一个数组中,随后创建新的结点存储数组中的每个元素,从二叉树的根节点开始,将left指针置为NULL,right指针指向下一个创建的新结点。

typedef struct TreeNode TN;


//先序遍历存储二叉树结点

void GetNodeVal(TN* root,int* arr,int* size)

{

    if(root==NULL)

    {

        return;

    }

    arr[(*size)++] = root->val;

    GetNodeVal(root->left,arr,size);

    GetNodeVal(root->right,arr,size);

}

//创建新结点存储数组中的元素,将结点的left置为NULL,right指向下一个创建的结点

TN* ListTree(int* arr,int size,int* num)

{

    if((*num)==size)

    {

        return NULL;

    }

    TN* node = (TN*)malloc(sizeof(TN));

    node->val = arr[(*num)++];

    node->left = NULL;

    node->right = ListTree(arr,size,num);

    return node;

}


 

void flatten(struct TreeNode* root)

{

    if(root==NULL)

    {

        return;

    }

    int arr[2001] = {0};

    int size = 0;

    GetNodeVal(root,arr,&size);

    int num = 1;

    root->left = NULL;

    root->right = ListTree(arr,size,&num);

}

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

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

相关文章

react中怎么为props设置默认值

在React中,你可以使用ES6的类属性(class properties)或者函数组件中的默认参数(default parameters)来定义props的默认值。 1.类组件中定义默认props 对于类组件,你可以在组件内部使用defaultProps属性来…

如何撰写EI会议的投稿信?

撰写EI会议的投稿信(Cover Letter)是向会议组织者介绍你的论文和研究工作的一个重要环节。以下是撰写投稿信的一些关键步骤和建议: 投稿信的结构 信头 你的信息:包括姓名、职位、单位名称、通讯地址、电子邮件和电话号码。日期&am…

力扣652. 寻找重复的子树

Problem: 652. 寻找重复的子树 文章目录 题目描述思路复杂度Code 题目描述 思路 1.利用二叉树的后序遍历将原始的二叉树序列化(之所以利用后序遍历是因为其在归的过程中是会携带左右子树的节点信息,而这些节点信息正是该解法要利用的东西); 2…

js积累二(web页面实现 时间走秒)

<tr><td class"ys04"><span class"ys02">当前时间&#xff1a;</span></td><td colspan"2"><span class"showTime"></span><script>var t null;t setTimeout(time, 1000); /…

【ai】chatgpt的plugin已经废弃

发现找不到按钮,原来是要申请: https://openai.com/index/chatgpt-plugins/ 发现申请已经跳转了,好像是废弃了? 不接受新插件了,但是openai的api 是可以继续用的。 https://openai.com/waitlist/plugins/We are no longer accepting new Plugins, builders can now create…

Windows11的这个地方暴露着你的隐私,把它关掉避免尴尬

前言 现在的电脑真的是越来越智能化&#xff01;现在有很多小伙伴都是用着Windows11的吧&#xff01;用习惯了Windows11之后&#xff0c;突然发现它还是挺顺手的。 但不知道你有没有发现&#xff0c;Windows11上面有个地方暴露着你的隐私。这个隐私可能是某个小姐姐的图片&am…

XSS---DOM破坏

文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 一.什么是DOM破坏 在HTML中&#xff0c;如果使用一些特定的属性名&#xff08;如id或name&#xff09;给DOM元素命名&#xff0c;这些属性会在全局作用域中创建同名的全局变量&#xff0c;指向对…

算法:最大连续子序列和

53. 最大子数组和 给你一个整数数组 nums &#xff0c;请你找出一个具有最大和的连续子数组&#xff08;子数组最少包含一个元素&#xff09;&#xff0c;返回其最大和。 子数组是数组中的一个连续部分。 class Solution:def maxSubArray(self, nums: List[int]) -> int:a…

Vue $nextTick作⽤是什么怎么使用

Vue中的$nextTick是一个非常重要的方法&#xff0c;主要用于在DOM更新后执行延迟回调。其工作原理基于Vue的异步更新队列机制。 当你在Vue实例上修改数据后&#xff0c;Vue并不会立即更新DOM&#xff0c;而是将这些修改操作推入一个队列中&#xff0c;并在下一个事件循环的“t…

Shell | shell脚本中使用cp指令(外两则)

sample"ENCFF253NIN" #等号两侧避免使用空格 source_path"/home/xxzhang/workplace/project/CRISPRa/Pacbio/CCS_TE.2/" target_path"./" cp "$source_path"/00-common_all.vcf.gz "$target_path" cp "$source_path&qu…

如何在Python中实现迭代器和可迭代对象

在Python中&#xff0c;可迭代对象&#xff08;iterable&#xff09;是一个对象&#xff0c;它可以返回一个迭代器&#xff08;iterator&#xff09;用于遍历其元素。迭代器是一个对象&#xff0c;它有一个 __next__() 方法&#xff08;在Python 2中&#xff0c;它是 next() 方…

LiveGBS流媒体平台GB/T28181用户手册-用户管理:添加用户、编辑、关联通道、搜索、重置密码

LiveGBS流媒体平台GB/T28181用户手册-用户管理:添加用户、编辑、关联通道、搜索、重置密码 1、用户管理1.1、添加用户1.2、编辑用户1.3、关联通道1.4、重置密码1.5、搜索1.6、删除 2、搭建GB28181视频直播平台 1、用户管理 1.1、添加用户 添加用户&#xff0c;可以配置登陆用户…

STM32-按键控制LED

接上篇LED点亮;http://t.csdnimg.cn/9r6z7 目录 一.硬件设计 二.软件设计 三.完整代码 四.结束语 一.硬件设计 按钮接电源插入PB0引脚,如上图所示 二.软件设计 void key_init() {GPIO_InitTypeDef GPIO_InitStruct;//使能时钟RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIO…

【LeetCode:496. 下一个更大元素 I + 单调栈】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

问题解决记录1:nvidia-container-cli: initialization error: load library failed

本地docker运行 $ docker run --rm --gpus all nvidia/cuda:11.8.0-base-ubuntu22.04 nvidia-smi 遇到这种报错 Error response from daemon: failed to create shim task: OCI runtime create failed: runc create failed: unable to start container process: error dur…

案例分享|Alluxio在自动驾驶模型训练中的应用与部署

分享嘉宾&#xff1a; 杨林三-辉羲智能 关于辉羲智能&#xff1a; 辉羲智能致力打造创新车载智能计算平台&#xff0c;提供高阶智能驾驶芯片、易用开放工具链及全栈自动驾驶解决方案&#xff0c;运用独创性“数据闭环定义芯片”方法学&#xff0c;助力车企构建低成本、大规模和…

百度生成数据库

问题1&#xff1a; 帮我创建2个表student与score表&#xff0c;要求student表有id,createDate,userName,phone,age,sex,introduce&#xff0c; 要求score表有id,scoreName,result,studentId(student表的id外键)。 要求student表中插入5条学生信息&#xff0c;都要是中文的。 要…

docker flow

docker --version docker build -t tagname:version docker run --networknetwork --namename -p port:port imageName docker rmi docker rm docker images docker rm docker start docker stop

设计模式5——抽象工厂模式

写文章的初心主要是用来帮助自己快速的回忆这个模式该怎么用&#xff0c;主要是下面的UML图可以起到大作用&#xff0c;在你学习过一遍以后可能会遗忘&#xff0c;忘记了不要紧&#xff0c;只要看一眼UML图就能想起来了。同时也请大家多多指教。 抽象工厂模式&#xff08;Abst…

每日5题Day8 - LeetCode 36 - 40

每一步向前都是向自己的梦想更近一步&#xff0c;坚持不懈&#xff0c;勇往直前&#xff01; 第一题&#xff1a;36. 有效的数独 - 力扣&#xff08;LeetCode&#xff09; 题目要求我们进行判断&#xff0c;我们不需要自己填写&#xff0c;所以要一个标志位&#xff0c;来看当…