我昨天完成了这些功能的组合,它基本上是一个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;
}
}
答案 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