力扣94题,及相对应的指针知识

文章讲述了在C语言中如何使用指针在函数(包括递归函数)中改变变量的值,以及在处理树结构时如何进行中序遍历并动态分配内存存储结果。递归函数`zhongxu`用于更新整型变量或数组,`inorderTraversal`函数则演示了如何返回一个包含树节点值的数组及其大小。文章还强调了指针操作的顺序,如`*p++`和`(*p)++`的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    简单一道题,卡了有些天,发现是有些忘记了的指针知识,特意回顾一手,假如是有

int a 这个整形,要想在函数中改变他则需要,往函数里传a的地址,这个我是知道的,但是我忘记了,在递归函数中要改变a实际上传i就行,那么二级指针也是相同的意思,如果是要改变指针i那么是需要传i的地址。

#include"stdio.h"
void zhongxu(int*i){
  (*i)++;
    printf("%d\n", *i);
}


int main () {
        int a=1;
     zhongxu(&a);
    printf("%d",a);
    
   
   
return 0;
}




输出的两个都是2


​​​​​​​

首先本题有个潜在的难点就是如果要具体的算树节点,来具体的申请内存,就要用到这个函数

int size(struct TreeNode*root){
return root==NULL?0:size(root->left)+size(root->right)+1

}

如果root为空,就返回0,否则就计算总共的节点从左树开始递归。

void zhongxu(struct TreeNode*root,int*a,int *i){
    if(root==NULL)
    return;
      
      zhongxu(root->left,a,i);
      a[*i]=root->val;
      (*i)++;
      zhongxu(root->right,a,i);
}
int* inorderTraversal(struct TreeNode* root, int* returnSize){
        int i=0;
        int*a=malloc(sizeof(int)*101);
         zhongxu(root,a,&i);
         *returnSize=i;
        return a;
}

输出的时候,多个数字,但是函数只能返回一个值,所以需要返回数组。开始往数组里面存树里面的值,然后让i++赋给下一个值

返回数组也是返回他的首地址,returnSize是要取出数组有多少个,从而取出完整的数组。

然后一个注意点 *p++  

是先++后*,也就相当于*(p++)假如数组是{1,3,5,7,9)

p就会变成3,也就是下一个元素。但是输出时printf("%d", *p++); 输出会输出1

(*p)++。  先*再+1,所以p会变成2,同时他的printf("%d",(*p)++);输出也是输出1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

狗哥不是甜妹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值