会员网站模板wordpress手机app主题
web/
2025/10/4 18:17:12/
文章来源:
会员网站模板,wordpress手机app主题,图书电子商务网站建设,自己的域名可以转给做网站的账号吗https://leetcode.cn/problems/binary-tree-preorder-traversal/ 这道题目需要我们自行进行创建一个数组#xff0c;题目也给出我们需要自己malloc一个数组来存放#xff0c;这样能达到我们遍历的效果#xff0c;我们来看看他的接口函数给的是什么。 可以看到的是这个接口函… https://leetcode.cn/problems/binary-tree-preorder-traversal/ 这道题目需要我们自行进行创建一个数组题目也给出我们需要自己malloc一个数组来存放这样能达到我们遍历的效果我们来看看他的接口函数给的是什么。 可以看到的是这个接口函数给了一个root就是根节点的意思但是这里的returnsize是什么意思可能有问题
其实returnsize这里虽然给的是指针是因为我们函数栈帧创建和销毁的时候形参只是实参的一份临时拷贝这样的话我们就算给returnsize赋值进行改变也不能改变他的值 这里的returnsize是我们需要在这个函数外面统计数组的个数 我们来看这个题目的第一个问题就是我们要开辟一个数组开辟数组的话我们是不是得知道这个数组空间有多大才行所以我们得先写一个函数就是统计节点的函数那这个函数其实就是遍历数组用的就是递归的方式进行遍历。
int BinaryTreeSize(struct TreeNode* root)
{if(root NULL){return 0;}return BinaryTreeSize(root-left) BinaryTreeSize(root-right) 1;
}
这个就是我们来统计有多少节点的函数思想就是我们遇到空的时候就返回不是空的时候就是得返回一个节点。下面我们就只需要在题目给的接口函数进行调用然后malloc一个数组出来就行。
int* preorderTraversal(struct TreeNode* root, int* returnSize) {int n BinaryTreeSize(root);int* arry (int*)malloc(sizeof(int)*n);assert(arry);int size 0;_preorderTraversal(root, arry, size);*returnSize n;return arry;}
然后我们需要做的就是实现我们遍历函数的内容其实很简单因为前序遍历的时候是先中间节点然后是他的左孩子和右孩子所以我们的递归方法就出来了。
void _preorderTraversal(struct TreeNode* root, int* a,int* pi)
{if(root NULL){return ;}a[(*pi)] root-val;_preorderTraversal(root-left, a, pi);_preorderTraversal(root-right, a, pi);}
这里需要注意的地方就是pi这个值我们是需要取出他的地址进行因为如果不是地址的话我们每次函数递归的时候建立函数栈帧的时候就是会有问题每次都是局部变量所以我们得用他的地址这个也就是为什么我们的size是取地址传进来的而不是直接传0因为传0的话形参只是实参的一份临时拷贝改变形参并不会对实参有任何的影响。 谢谢大家观看我们下次再见。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/86920.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!