news 2026/6/22 22:34:45

树的练习1--------965单值二叉树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
树的练习1--------965单值二叉树

前言

终于度过期末周啦,我要尽快把我的节奏调整过来,留给我的时间不多啦,我的学习和生活模式需要大改变,我需要通过自己清晰的头脑,让环境顺于我去发展,或者说我可以改变思路,改变自己去适应这个环境

题目:点这里

解法

/** * 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 isUnivalTree(TreeNode* root) { if(root==nullptr){ return true; } if(root->left){ if(root->val!=root->left->val){ return false; } if(isUnivalTree(root->left)==false){ return false; } } if(root->right){ if(root->val!=root->right->val){ return false; } if(isUnivalTree(root->right)==false){ return false; } } return true; } };

这个解法的思路就是首先判断根节点是不是为空,为空则返回true,然后利用if语句判断根节点的左节点是否为空,不为空则首先判断根节点与左节点的值是否相等,不等则返回false,再将左节点传入下一层函数,若返回值为false,则也返回false,右节点同理,最终如果都不成立,就返回true。

我的错误解法

/** * 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 isUnivalTree(TreeNode* root) { if(root->left==nullptr||root->right==nullptr){ return true; } if(root->val!=root->left->val||root->val!=root->right->val){ return false; } else{ return isUnivalTree(root->left)==false||isUnivalTree(root->right)==false?false:true; } } };

我的错误在于没有对根节点和左右节点分开进行讨论,导致指针越界访问。

反思

看情况对左右节点分情况讨论;

为递归预留出口,也就是对根节点是否为空进行优先判断。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/20 11:26:57

没显卡怎么跑GPT-OSS?云端GPU镜像2块钱玩转AI智能体

没显卡怎么跑GPT-OSS?云端GPU镜像2块钱玩转AI智能体 你是不是也遇到过这种情况:手头有个超棒的AI项目想试试,比如用 GPT-OSS-20B 构建一个能自动查数据库、调API、写报告的智能体工作流,结果一看官方文档——“建议16GB显存”&am…

作者头像 李华
网站建设 2026/6/15 18:02:21

用YOLOE做自动化流水线检测,节省90%人力

用YOLOE做自动化流水线检测,节省90%人力 在现代智能制造场景中,产品质量检测是保障产线效率与产品一致性的关键环节。传统人工质检不仅成本高昂、效率低下,还容易因疲劳导致漏检误检。随着AI视觉技术的发展,基于深度学习的目标检…

作者头像 李华
网站建设 2026/6/22 13:31:59

Polars DataFrame中的复杂计算与Numba优化

在数据处理领域,Polars是一个高效且快速的数据框架,提供了诸如Pandas的类似功能,但性能更优。然而,当涉及到复杂的自定义函数计算时,Polars的处理方式可能不尽如人意,特别是当你需要在DataFrame中进行多列的计算并保留中间结果时。本文将探讨如何通过Numba优化和Polars的…

作者头像 李华
网站建设 2026/6/13 13:18:02

python基于vue的高校学生成绩管理系统设计与实现django flask pycharm

目录高校学生成绩管理系统设计与实现摘要开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!高校学生成绩管理系统设计与实现摘要 该系统基于Python语言,采用Vue.js前端框架与Djang…

作者头像 李华
网站建设 2026/6/13 23:06:24

DeepSeek-R1-Distill-Qwen-1.5B部署全流程:从镜像拉取到接口调用

DeepSeek-R1-Distill-Qwen-1.5B部署全流程:从镜像拉取到接口调用 1. 引言 随着大模型在实际业务场景中的广泛应用,轻量化、高效率的推理部署方案成为工程落地的关键。DeepSeek-R1-Distill-Qwen-1.5B作为一款基于知识蒸馏技术优化的小参数量语言模型&am…

作者头像 李华
网站建设 2026/6/18 1:44:54

Qwen3-VL增强推理模式:复杂任务分解部署实战案例

Qwen3-VL增强推理模式:复杂任务分解部署实战案例 1. 背景与技术定位 随着多模态大模型在真实场景中的应用不断深化,单一的文本或图像理解已无法满足日益复杂的交互需求。阿里开源的 Qwen3-VL-2B-Instruct 模型作为 Qwen 系列中迄今最强大的视觉-语言模…

作者头像 李华