news 2026/5/1 11:33:37

树的练习7--------LCR 052.递增顺序搜索树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
树的练习7--------LCR 052.递增顺序搜索树

前言

今天这一题也是非常的憋屈,在递归上的运用可谓是得心应手,但是在一些小细节上却存在着致命的问题,现在来总结一下。

题目:点这里

解法:

/** * 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> ret; int num; void inOrder(TreeNode* root){ if(root){ inOrder(root->left); ret.push_back(root->val); inOrder(root->right); } } TreeNode* dfs(int num){ if(num==ret.size()){ return NULL; } TreeNode* root = new TreeNode(ret[num]); root->right = dfs(++num);//如果是num++,那代表num是先传入再递增,传入的num的值永不改变,如果是++num,则代表是先递增后传入,虽然每次传入的num都增值了,但是本层函数中的num也增加了,这就使得后续传参错位。 root->left = NULL; // root->val = ret[num]; return root; } TreeNode* increasingBST(TreeNode* root) { ret.clear(); num = 0; inOrder(root); return dfs(num); } };

这个题目的思路很清晰,就是先将二叉搜索树利用前序遍历存入到数组中,然后将数组中的值利用遍历生成一棵符合要求的树。

小问题出现在第二步上,由于这棵树需要利用数组,所以我将索引作为形参来传递,但是在每次传入的值这里出了问题,如果传入的是num++,代表先传入后增值,那么在递归过程中num就不会改变了,也就进入了无穷次的递归;但如果改成++num,则代表先递增后传入,这样的话虽然num的值发生了改变,但是每一层的num却都加了不该加的1,导致归的时候根节点的赋值出现了错位,所以也是不对的;

我选择的补救措施是在递的时候提前赋值,就是这一行语句:

TreeNode* root = new TreeNode(ret[num]);

配合++num就能完美解决问题。

反思

还有这里相比用形参来传值,更好的做法是利用引用,这样可以增强代码的简洁性和可读性

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

计算机大数据毕设实战-基于hadoop的山东瓜果蔬菜分析系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】

java毕业设计-基于springboot的(源码LW部署文档全bao远程调试代码讲解等) 博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、…

作者头像 李华
网站建设 2026/5/1 8:49:41

深度测评8个AI论文写作软件,本科生轻松搞定毕业论文!

深度测评8个AI论文写作软件&#xff0c;本科生轻松搞定毕业论文&#xff01; AI 工具如何让论文写作变得轻松高效&#xff1f; 在当前的学术环境中&#xff0c;越来越多的本科生开始借助 AI 工具来辅助论文写作。无论是开题报告、文献综述还是最终的论文撰写&#xff0c;这些工…

作者头像 李华
网站建设 2026/5/1 11:07:31

SSM298的勤工助学管理系统vue

目录SSM298勤工助学管理系统Vue摘要开发技术源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;SSM298勤工助学管理系统Vue摘要 该系统基于SSM&#xff08;SpringSpringMVCMyBatis&#xff09;框架与Vue.js前端技术开发&#xff0c;旨在为…

作者头像 李华
网站建设 2026/5/1 10:02:16

2026年11项惊人工程技术突破即将到来

脑芯片帮助盲人重见光明埃隆马斯克表示&#xff0c;他的公司Neuralink计划在2026年帮助完全失明的患者恢复部分视力。该公司计划在今年早期对其最新、最强大的植入物Blindsight进行人体测试。该芯片将无线连接到外部摄像头&#xff0c;并植入大脑视觉皮层。通过绕过眼睛&#x…

作者头像 李华
网站建设 2026/5/1 9:10:32

MagSafe星期一:Anker超薄Qi2电池包成为EDC装备完美搭档

个人而言&#xff0c;我很想购买iPhone 17 mini&#xff0c;但无论如何&#xff0c;Max机型对我的前口袋来说太大了&#xff0c;我更喜欢能够单手使用手机。然而&#xff0c;坚持使用较小电池容量的机型迫使我重新思考我的EDC装备。由于我不会拥有Pro Max的大容量电池&#xff…

作者头像 李华