数据结构-leetcode-数组形式的整数加法

解题图解:

下面是代码:

cpp 复制代码
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* addToArrayForm(int* num, int numSize, int k, int* returnSize){
    int k_tem =k;
    int klen=0;
    while(k_tem){//看看k有几位
        k_tem /=10;
        klen++;
    }
    int len = numSize>klen?numSize:klen;
    int *arry =(int*)malloc(sizeof(int)*(len+1));
    int num_end=numSize-1;
    int number_in=0;
    for(int i=0;i<len;i++){
        int a=0;
        if(num_end>=0){//k的位数比提供的数组大的情况
            a=num[num_end];
        }
        int bit_number=a+k%10+number_in;
        k/=10;
        number_in=0;
        if(bit_number>=10){
            arry[i]=bit_number-10;
            number_in=1;
        }else{
            arry[i]=bit_number;
        }
        num_end--;
    }
    int flag=0;//用于判断开辟的数组最后是len,还是len+1
    if(number_in==1){//如果最后一位需要进位就让开辟好的数组最后一位置为1
        arry[len]=1;
        flag=1;
    }
    int arry_end=(flag==1?len:len-1);
    int arry_start=0;
    while(arry_start<arry_end){
        //不用临时变量交换数组,可以学一下
        arry[arry_start]=arry[arry_start]^arry[arry_end];
        arry[arry_end]=arry[arry_start]^arry[arry_end];
        arry[arry_start]=arry[arry_start]^arry[arry_end];
        arry_end--;
        arry_start++;
    }
    *returnSize=(flag==1?len+1:len);
    return arry;
}
相关推荐
little redcap12 分钟前
第十九次CCF计算机软件能力认证-乔乔和牛牛逛超市
数据结构·c++·算法
muyierfly44 分钟前
34.贪心算法1
算法·贪心算法
luthane3 小时前
python 实现average mean平均数算法
开发语言·python·算法
静心问道3 小时前
WGAN算法
深度学习·算法·机器学习
杰九4 小时前
【算法题】46. 全排列-力扣(LeetCode)
算法·leetcode·深度优先·剪枝
manba_4 小时前
leetcode-560. 和为 K 的子数组
数据结构·算法·leetcode
liuyang-neu4 小时前
力扣 11.盛最多水的容器
算法·leetcode·职场和发展
忍界英雄4 小时前
LeetCode:2398. 预算内的最多机器人数目 双指针+单调队列,时间复杂度O(n)
算法·leetcode·机器人
Kenneth風车4 小时前
【机器学习(五)】分类和回归任务-AdaBoost算法-Sentosa_DSML社区版
人工智能·算法·低代码·机器学习·数据分析
C7211BA4 小时前
使用knn算法对iris数据集进行分类
算法·分类·数据挖掘