我正在尝试使用(Eratosthenes筛子)方法查找质数,但是当我运行程序时,在CLion中遇到了以下错误。错误是关于第6行中的ara [size]的问题。如何解决该问题并运行程序?我的代码中没有看到其他错误。还有办法使我的代码比这种方法更有效吗?
**error: variably modified 'ara' at file scope
6 | int ara[size];
| ^~~
make[3]: *** [CMakeFiles/C_Practise.dir/build.make:83: CMakeFiles/C_Practise.dir/main.c.o] Error 1
make[2]: *** [CMakeFiles/Makefile2:96: CMakeFiles/C_Practise.dir/all] Error 2
make[1]: *** [CMakeFiles/Makefile2:103: CMakeFiles/C_Practise.dir/rule] Error 2
make: *** [Makefile:138: C_Practise] Error 2"**
#include <stdio.h>
#include <math.h>
const int size = 40;
int ara[size];
void print_ara()
{
int i;
for(i = 2; i < size; i++){
printf("%4d", ara[i]);
}
printf("\n");
for(i = 2; i < size; i++){
printf("----");
}
printf("\n");
for(i = 2; i < size; i++){
printf("%4d", i);
}
printf("\n\n\n");
}
void sieve()
{
int i, j , root;
for(i = 2; i < size; i++){
ara[i] = 1;
}
root = sqrt(size);
print_ara();
for(i = 2; i <= root; i++){
if(ara[i] == 1){
for(j = 2; i * j <= size; j++)
{
ara[i * j] = 0;
}
print_ara();
}
}
}
int is_prime(int n)
{
int i;
if(n < 2) {
return 0;
}
return ara[n];
}
int main()
{
int n, m;
sieve();
while (1){
printf("Please enter a number(enter 0 to exit): ");
scanf("%d", &n);
if(n == 0) {
break;
}
if(n >= size) {
printf("The number should be less than %d\n", size);
continue;
}
if(1 == is_prime(n)) {
printf("%d is a prime number.\n", n);
} else{
printf("%d is not a prime number.\n", n);
}
}
return 0;
}
答案 0 :(得分:0)
您不能在C中使用const定义数组。这个here有很好的解释
相反,正确的方法是使用#define。
因此,如果您从此更改数组声明:
const int size = 40;
int ara[size];
对此:
#define size 40
int ara[size];
它将编译。