news 2026/3/12 21:42:11

树的练习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/3/9 14:12:44

SSM293的农家乐系统-住宿-美食-活动vue

目录SSM293农家乐系统概述住宿管理模块美食预订模块活动预约模块技术实现与优势开发技术源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;SSM293农家乐系统概述 SSM293农家乐系统基于Vue.js前端框架开发&#xff0c;整合住宿管理、美食预…

作者头像 李华
网站建设 2026/3/7 13:21:29

全网最全专科生必备TOP8 AI论文写作软件测评

全网最全专科生必备TOP8 AI论文写作软件测评 2026年专科生必备AI论文写作软件测评&#xff1a;为何需要这份榜单&#xff1f; 随着人工智能技术的不断发展&#xff0c;越来越多的学术辅助工具涌现出来&#xff0c;为学生和研究人员提供了高效、便捷的写作支持。对于专科生而言&…

作者头像 李华
网站建设 2026/3/11 19:06:55

SSM280的课程智能组卷考试系统vue

目录SSM280课程智能组卷考试系统&#xff08;Vue版&#xff09;摘要开发技术源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;SSM280课程智能组卷考试系统&#xff08;Vue版&#xff09;摘要 SSM280课程智能组卷考试系统是基于SpringSpr…

作者头像 李华
网站建设 2026/3/12 16:52:27

深度测评研究生必备9款AI论文平台:开题文献综述全解析

深度测评研究生必备9款AI论文平台&#xff1a;开题文献综述全解析 2026年研究生AI论文平台深度测评&#xff1a;功能与效率的全面解析 随着人工智能技术在学术领域的不断渗透&#xff0c;越来越多的研究生开始依赖AI工具提升论文写作效率。然而&#xff0c;面对市场上琳琅满目的…

作者头像 李华
网站建设 2026/3/11 18:40:19

AI系统架构设计实战:AI应用架构师的深度指南

AI系统架构设计实战:AI应用架构师的深度指南 关键词:AI系统架构、机器学习架构、深度学习架构、数据工程、MLOps、模型部署、AI可扩展性 摘要: 在人工智能飞速发展的今天,构建稳健、高效、可扩展的AI系统架构已成为企业成功实施AI战略的关键。本文作为AI应用架构师的深度…

作者头像 李华
网站建设 2026/3/4 13:29:11

大数据计算机毕设之基于机器学习的网络购物平台的智能推荐(完整前后端代码+说明文档+LW,调试定制等)

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

作者头像 李华