我有一个素数数组。该数组的长度为1,000,000。这意味着我的最后一个元素primes [999999]应该有100万个素数,实际上它应该有1,000,001个素数,因为我离开了2个开头。
当我运行我的程序并让它吐出数组的最后一个元素时,它会吐出第999,999个素数。我正在学习C,这是我正在学习的数学课程的一个小作业项目。我不知道从哪里开始解决这个问题。任何帮助将不胜感激。
编辑:抱歉,由于某种原因,我认为这可能是一个简单的答案。我发布了以下代码。我已经打印出选项1下的素数数组,所有素数都是正确的,结果是正确的。任何其他选项,我得到一个错误的输出。void createArray( int, unsigned long long * );
unsigned long long root(unsigned long long);
void print( unsigned long long *, int );
int main(void){
unsigned long long *prime = (unsigned long long *)calloc(SIZE6,
sizeof(unsigned long long));
unsigned long long *ptrEmpty = &prime[15];
unsigned long long i;
unsigned long long j;
long int sizeComp;
int flag = 0;
unsigned long option = 0;
int length = 0;
system( "clear" );
do{
flag = 0;
option = -1;
printf( "Welcome to the prime number finder program. Below are a list "
"of prime numbers\nyou can find as well as their average runni"
"ng time on the Loki system of UNO.\n\nOption 1: Return the 10"
"0th prime number. ( Running time: .006s )\nOption 2: Return t"
"he 1000th prime number. ( Running time: .008s )\nOption 3: Re"
"turn the 10000th prime number. ( Running time: .089s )\nOptio"
"n 4: Return the 100000th prime number. ( Running time: 2.188s"
" )\nOption 5: Return the 1000000th prime number. ( Running ti"
"me: 57.156s )\nOption 6: Return the 10000000th prime number. "
"( **CAUTION!** Running time: 35m51.3s )\n\nEnter the number o"
"f the option you would like the program to\nperform (Enter 0 "
"to exit): " );
scanf( "%lu", &option );
switch( option ){
case 0:
flag = 1;
break;
case 1:
createArray( SIZE1, prime );
ptrEmpty = &prime[15];
length = SIZE1;
break;
case 2:
createArray( SIZE2, prime );
ptrEmpty = &prime[15];
length = SIZE2;
break;
case 3:
createArray( SIZE3, prime );
ptrEmpty = &prime[15];
length = SIZE3;
break;
case 4:
createArray( SIZE4, prime );
ptrEmpty = &prime[15];
length = SIZE4;
break;
case 5:
createArray( SIZE5, prime );
ptrEmpty = &prime[15];
length = SIZE5;
break;
case 6:
createArray( SIZE6, prime );
ptrEmpty = &prime[15];
length = SIZE6;
break;
default:
printf( "Please enter one of the available options ( 1 - 7 ) "
"or 0 to exit: " );
flag= 1;
break;
}
if( flag != 1 ){
for( i = START, sizeComp = 15; sizeComp <= length; i += 2 ){
flag = 0;
for( j = 0; prime[j] < root( i ); j++ ){
if( ( i % prime[j] ) == 0 ){
flag = 1;
break;
}
}
if( flag == 0 ){
*ptrEmpty = i;
++sizeComp;
ptrEmpty++;
}
}
printf( "\nThe %dth prime number is %llu.\n\n", length,
prime[ length - 2 ]);
// print( prime, length );
printf( "****************************************"
"****************************************\n\n" );
}
}while( option != 0 );
free( prime );
return 0;
}
void print( unsigned long long *prime, int length ){
int i;
printf( "\n%4d", 2 );
for( i = 0; i < length; i++){
printf( "%4llu ", prime[i] );
}
printf( "\n" );
}
void createArray( int length, unsigned long long *prime ){
unsigned long long *pHolder = NULL;
pHolder = (unsigned long long *)realloc( prime, length *
sizeof( unsigned long long ) );
if(pHolder != NULL){
prime = pHolder;
}else{
free( prime );
printf( "Error reallocating memory.\n" );
exit(1);
}
prime[0] = 3;
prime[1] = 5;
prime[2] = 7;
prime[3] = 11;
prime[4] = 13;
prime[5] = 17;
prime[6] = 19;
prime[7] = 23;
prime[8] = 29;
prime[9] = 31;
prime[10] = 37;
prime[11] = 41;
prime[12] = 43;
prime[13] = 47;
prime[14] = 53;
}
unsigned long long root(unsigned long long a) {
unsigned long long rem = 0;
unsigned long long root = 0;
int i;
for (i = 0; i < 16; i++) {
root <<= 1;
rem <<= 2;
rem += a >> 30;
a <<= 2;
if (root < rem) {
root++;
rem -= root;
root++;
}
}
return (root >> 1);
}
编辑: SIZE1 = 100,SIZE2 = 1000,SIZE3 = 10000,SIZE4 = 100000,SIZE5 = 1000000,SIZE6 = 10000000
答案 0 :(得分:3)
您可以通过将数组大小更改为5并仅查看前5个素数,打印出所有5个素数,并查看它是否实际为2 3 5 7 11(或在您的情况下为3 5)来进行调试。 7 11 13)或者如果你有一些错误。
您的错误可能存在于那里,然后您可以针对更小的情况进行更正,它应该适用于更大的情况。