[略略略] 2022-02-18 18:25 采纳率: 47.8%
浏览 35
已结题

leetcode第66题,我这么写是错在哪里了

我c语言和数据结构都不熟,最近在刷leetcode,这个程序自己手推好像没有错,不知道错在哪里了,如果直接看别人的代码写,感觉就永远不会知道我这么写的问题在哪,所以上来问问大lao们

这是问题和我写的代码

img

img

int* plusOne(int* digits, int digitsSize, int* returnSize){
    int flag=1,loc=digitsSize-1;    //flag是进位,因为加一,所以初始值为1,loc是从后向前的下标
    if(digits[0]==0){               //如果数组是0,就直接返回1
        returnSize=(int *)malloc(sizeof(int));
        returnSize[0]=1;
    }
    else{
        while(loc>-1){
            digits[loc]=digits[loc]+flag;
            flag=digits[loc]/10;
            digits[loc]=digits[loc]%10;
            loc--;
        }
        if(flag>0){
            digitsSize++;
            returnSize=(int *)malloc(sizeof(int)*digitsSize);
            returnSize[0]=flag;
            for(int j=1;j<digitsSize;j++)returnSize[j]=digits[j-1];
        }
        else{               //如果算到最大一位还有进位,就得全体先后挪,然后进1
            returnSize=(int *)malloc(sizeof(int)*digitsSize);
            for(int j=0;j<digitsSize;j++)returnSize[j]=digits[j];
        }       
    }
    return returnSize;
}

麻烦大家帮我看看.万分谢谢

  • 写回答

2条回答 默认 最新

  • aabyte 2022-02-18 18:49
    关注

    猜测 returnSize 是用来返回答案数组的长度的,因为传的是地址,所以在函数里 解引用之后 赋上数组的长度就好了,然后函数的返回值是答案数组的首地址

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月26日
  • 已采纳回答 2月18日
  • 创建了问题 2月18日

悬赏问题

  • ¥15 关于c++外部库文件宏的问题,求解
  • ¥15 office打开卡退(新电脑重装office系统后)
  • ¥300 FLUENT 火箭发动机燃烧EDC仿真
  • ¥15 【Hadoop 问题】Hadoop编译所遇问题hadoop-common: make failed with error code 2
  • ¥15 vb6.0+webbrowser无法加载某个网页求解
  • ¥15 RPA财务机器人采购付款流程
  • ¥15 计算机图形多边形及三次样条曲线绘制
  • ¥15 根据protues画的图用keil写程序
  • ¥200 如何使用postGis实现最短领规划?
  • ¥15 pyinstaller打包错误