我需要找到一个数字的所有质因数。我已经编写了这段代码,但是当我尝试使用 realloc 在 calculatePrimes 函数中重新分配指针数组时,gcc 会给出错误,即我在使用 realloc 之前没有分配指针。我知道我可以在calculatePrimes 函数中传递双指针并使用malloc,或者使用单指针并返回值。
代码:
#include "stdio.h"
#include <math.h>
#include <stdlib.h>
void calculatePrimes(int max, int** array){
int size=1, i;
*array[0]=2;
for(i=0; i<max; i++){
if(isPrime(i)){
*array = (int *)realloc(**array, (++size)*sizeof(int));
*array[size-1]=i;
}
}
}
int isPrime(int value){
int i=2, root = sqrt(value);
for(;i<root;i++){
if(value%i==0) return 0;
}
return 1;
}
void main(int argc, char*argv[]){
int input = atoi(argv[1]), numPrimes;
int *primes=(int *)malloc(sizeof(int));
calculatePrimes(input, &primes);
numPrimes=sizeof(primes)/sizeof(int);
printf("%d\n", numPrimes);
free(primes);
}