我昨天完成了把这些函数放在一起,它基本上是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;
}
}
发布于 2018-06-07 07:39:13
分配一个大小为int9的新数组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
https://stackoverflow.com/questions/50730977
复制相似问题