力扣94. 二叉树的中序遍历

1.解题思路

与前序遍历相同,相同的思路,将树的值存到数组中,所以在申请空间的时候,我们需要知道要申请多少空间,也就是要知道树到底有多少个结点,因此第一步要写个函数实现获得树的节点数,又因为该题提供的接口里写了申请空间,因为本题自带的接口不适合递归,所以我们可以将递归操作再另外写个函数来实现只不过在遍历的时候要遵循中序

2.代码实现



 int GetNum(struct TreeNode* root)
{
   
    if(root==NULL)
    return 0;
    return GetNum(root->left)+ GetNum(root->right)+1;
}
void Traversal(struct TreeNode* root,int *a, int* pi)
{
      if(root==NULL)
return ;
   Traversal(root->left,a, pi);
      a[(*pi)]=root->val;
    (*pi)++;
   Traversal(root->right,a, pi);

}
int* inorderTraversal(struct TreeNode* root, int* returnSize) 
{
   
     int size=GetNum(root);
   int *a=(int*)malloc(sizeof(int)*size);
       int pi=0;
    Traversal(root,a,&pi);
    * returnSize=size;
    return a;

}



结尾:今天的分享到此结束,喜欢的朋友如果感觉有帮助可以点赞三连支持,咱们共同进步!

相关推荐

  1. 94.

    2023-12-16 21:34:03       50 阅读
  2. 94-

    2023-12-16 21:34:03       57 阅读
  3. 94.

    2023-12-16 21:34:03       44 阅读
  4. -

    2023-12-16 21:34:03       28 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-16 21:34:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-16 21:34:03       101 阅读
  3. 在Django里面运行非项目文件

    2023-12-16 21:34:03       82 阅读
  4. Python语言-面向对象

    2023-12-16 21:34:03       91 阅读

热门阅读

  1. LeetCode215. Kth Largest Element in an Array

    2023-12-16 21:34:03       53 阅读
  2. C语言—每日选择题—Day49

    2023-12-16 21:34:03       51 阅读
  3. Android audio设置投屏和喇叭双输出

    2023-12-16 21:34:03       94 阅读
  4. 2276. 统计区间中的整数数目

    2023-12-16 21:34:03       56 阅读
  5. C++改写为C

    2023-12-16 21:34:03       61 阅读
  6. JVM源码剖析之信号处理机制

    2023-12-16 21:34:03       40 阅读
  7. Ubuntu 命令行安装 Clang 16或者Clang 17的过程

    2023-12-16 21:34:03       55 阅读