#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]);
}
编写函数,判断该数组中哪些是素数,并统计素数的个数,在主函数中输出素数的个数和这些素数,函数原型不能变,怎么我一直输出不来,求大神指教!?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- bostonAlen 2019-12-16 22:34关注
提示一下,代码就编译不过,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; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 6无用
悬赏问题
- ¥15 运筹学排序问题中的在线排序
- ¥15 关于#flink#的问题:关于docker部署flink集成hadoop的yarn,请教个问题flink启动yarn-session.sh连不上hadoop
- ¥30 求一段fortran代码用IVF编译运行的结果
- ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
- ¥15 lammps拉伸应力应变曲线分析
- ¥15 C++ 头文件/宏冲突问题解决
- ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
- ¥50 安卓adb backup备份子用户应用数据失败
- ¥20 有人能用聚类分析帮我分析一下文本内容嘛
- ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题