当前位置: 首页 > news >正文

专业网站设计联系百度怎样免费发布信息

专业网站设计联系,百度怎样免费发布信息,软件定制开发是什么意思,e网站的图标怎么做https://leetcode.cn/problems/binary-tree-preorder-traversal/ 这道题目需要我们自行进行创建一个数组,题目也给出我们需要自己malloc一个数组来存放,这样能达到我们遍历的效果,我们来看看他的接口函数给的是什么。 可以看到的是这个接口函…

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.mnyf.cn/news/40428.html

相关文章:

  • 用来做网站的软件宁波seo企业网络推广
  • 网站接口需求app开发公司哪家好
  • 免费做图片链接网站邯郸百度推广公司
  • 硅云网站建设视频快速开发平台
  • 网站做标签免费行情软件网站下载大全
  • 中南建设的网站搜狗搜索引擎优化论文
  • 网站建设栏目层级com域名
  • 进入网站服务器怎么做精准引流推广公司
  • 苏州基础网站建设百度百家
  • 业务办理网站建设方案网站优化软件
  • 云主机建站关于网络推广的方法
  • 北京网站搭建服务迅雷磁力链bt磁力种子
  • 阆中做网站电子商务网站开发
  • 服装网站建设日程表中国知名网站排行榜
  • 关于网站开发的毕业论文应用商店aso
  • 盘锦做网站谁家好自建网站平台
  • 山西省建设注册中心网站首页网站建设7个基本流程
  • 知名网站建设定制近一周热点新闻
  • 关于网站建设毕业论文浑江区关键词seo排名优化
  • 网站一键生成手机网站fifa最新排名出炉
  • 网站开发常见问题seo技术论坛
  • 如何做网站域名免费浏览网站推广
  • 做网站都需要准备什么软件电商广告网络推广
  • 怎么可以做网站下载百度地图2022最新版
  • 建设p2p网站seo运营
  • 陇南市建设局官方网站西安霸屏推广
  • wordpress视频教程下载seo分析报告
  • 网站建设公司价格徐州自动seo
  • 网站建设规划设计书站内推广的方法
  • 修改散文网站百度注册公司网站