news 2026/5/12 7:21:21

树的练习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/5/5 6:34:34

大数据毕设选题推荐:基于hadoop的山东瓜果蔬菜分析系统【附源码、mysql、文档、调试+代码讲解+全bao等】

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

作者头像 李华
网站建设 2026/5/11 19:44:44

SSM286的旅游网站掌柜有礼vue

目录SSM286旅游网站掌柜有礼Vue摘要开发技术源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;SSM286旅游网站掌柜有礼Vue摘要 SSM286旅游网站采用Vue.js作为前端框架&#xff0c;结合Spring、SpringMVC和MyBatis&#xff08;SSM&#xf…

作者头像 李华
网站建设 2026/5/5 21:17:16

大模型本地部署,小号的vLLM来了!

文章介绍轻量级大模型推理引擎Nano-vLLM&#xff0c;这是代码简洁&#xff08;约1200行Python&#xff09;的vLLM替代实现。它提供快速离线推理能力&#xff0c;API与vLLM类似&#xff0c;在小模型测试中性能甚至优于vLLM。文章详解安装方法、模型下载途径&#xff08;包括mode…

作者头像 李华
网站建设 2026/4/19 21:07:44

【课程设计/毕业设计】基于python大数据的睡在地震数据可视化分析系统基于python的灾情数据可视化系统【附源码、数据库、万字文档】

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

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

【AI应用开发工程师】-分享Java 转 AI正确思路

☕ Java 转 AI&#xff1a;别翻书了&#xff0c;翻开你的 ChatGPT&#xff01; 中午和同事吃饭&#xff0c;聊起一个经典话题&#xff1a;“Java 程序员想转 AI&#xff0c;该看什么书&#xff1f;” 我抿了一口咖啡&#xff0c;缓缓放下杯子&#xff1a;“说实话&#xff0c;看…

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

2026项目管理工具推荐:7款免费版能做什么、卡在哪里

本文将深入对比7款免费项目管理工具&#xff1a;PingCode、Worktile、Jira Software、Trello、ClickUp、Notion、Asana。一、免费项目管理工具能做什么 很多团队找“免费项目管理工具”&#xff0c;一开始其实只想解决三件事&#xff1a;任务别丢、进度看得见、协作别靠催。可真…

作者头像 李华