为什么我的Luhn算法代码没有返回任何内容?

时间:2018-06-06 23:24:48

标签: c

我昨天完成了这些功能的组合,它基本上是一个Luhn算法的实现。第一个函数应该将整数和数组作为输入,然后将整数拆分为数字以填充数组。第二个应该检查数字是否有效并返回1或0.我的问题是,我可以告诉我的代码看起来没问题,并没有给出任何错误或警告,但当我尝试运行它没有任何反应。我很感激你的帮助。提前致谢

int populate_array(int raw_num, int num_array[]){
    //Assume length of raw_num will always be 9

    num_array= malloc(sizeof(int)*9); //Allocate memory for num_array
    int count=9;

    while (raw_num){
        num_array[count]=raw_num%10;
        raw_num=raw_num/10;
        count--;
        }
    return 0;
}

/*
*Takes an 9 element integer array representing a candidateSIN number.
*It returns 0 if the number given is a valid Canadian SIN number, and 1 otherwise.
*/

int sin_checker(int sin_array[]){ 
    int sin_sum=0;

    for (int i=1; i<9; i+=2){
        sin_array[i]*=2; 
        }

    for (int j=0; j<9;j++){
        if (sin_array[j]>9){
            sin_sum+= sin_array[j]/10;
            sin_sum+= sin_array[j]%10;
        }
        else{
            sin_sum+=sin_array[j];
        }
    }

    if (sin_sum % 10==0){
        return 0;
    }
    else{
        return 1;
    }
}

1 个答案:

答案 0 :(得分:0)

您分配一个大小为int [9]的新数组num_array。使用传递的那个,或者如果传递NULL则分配一个新的。

#define MAXDIGITS (10)

int*
populate_array(int raw_num, int* num_array)
{
    if(!num_array)
        num_array= malloc(sizeof(int)*9); //Allocate memory for num_array
    int count=MAXDIGITS-1;
    while (raw_num != 0){
        num_array[count--]=raw_num%10;
        if(count<0) break;
        raw_num=raw_num/10;
    }
    return 0;
}

通过传递NULL,使用返回的指针或传递数组

来调用它
int stuff[9];
int* pstuff = NULL;
populate_array(12345, stuff);
pstuff = populate_array(98765, NULL);
//then either print stuff, or pstuff