#include
int len ;
int IsPrime(int data, int *primes,int len)
{
int y=1;
for (int j = 0; j < 5; j++)/判断素数*/
{
for (int i = 2; i < data[j]; i++)
{
y = data[j] % i;
}
if (y != 0)
{
primes = &data[j];
len++;
primes++;
}
}
/*for (int i = 0; i < len; i++)
printf("%3d\n", *--primes);/
return len;
}
void main()
{
int data[5], *primes, primes_[5] = {1,2,3,4,5}, len = 0;
primes = primes_;
for (int i = 0; i < 5; i++)
{
scanf("%3d", &data[i]);
}
printf("共有%d个素数", len = IsPrime(data, primes, 0));
printf("这些素数分别为:\n");
for(int i=0;i<len;i++)
printf("%3d\n", primes_[len]);
}
提示一下,代码就编译不过,data是int类型,怎么能用下标访问呢,这里data应该是int*吧,把你的素数存下来。若你想看你错误的原因,用vs单步调试即可。
其实一开始建议你分开来写,一步一步来,下面是我就你的代码做了一些处理,可以参考下,
#include <stdio.h>
//判断一个数是否为素数
bool isPrime(int num)
{
int tmp = num - 1;
for (int i = 2; i <= tmp; i++)
if (num %i == 0)
return 0;
return 1;
}
//统计数组中素数的个数,并将素数保存到另一个数组中
/*
data 保存素数的数组
primes 需要判断的数组
len 数组长度
*/
int countPrime(int *data, int *primes, int len)
{
if (data == NULL || primes == NULL)
{
return 0;
}
int result = 0; // 素数的个数
for (int j = 0; j < len; j++)
{
if (isPrime(primes[j]))
{
result++;
data[j] = primes[j];
}
}
return result;
}
int main()
{
int data[5] = {0}, primes[5] = { 1, 2, 3, 4, 5 }, len = 5;
printf("素数个数为:%d\n",countPrime(data,primes,len));
printf("\n素数有:\n");
for (size_t i = 0; i < len; i++)
{
printf("%d\n", data[i]);
}
return 0;
}