#include "stdio.h"
int fun(int n)
{
int i, j = n, pd = 1;
for (i = 2; i < n; i++) {
if (j % i == 0) {
pd = 0;
}
}
if (pd == 1) {
return j;
}
else
fun(j + 1);
}
void main()
{
int n;
scanf("%d", &n);
printf("%d", fun(n));
}
要求函数返回比形参大的最小的素数,但我这样调用,j永远等于n,如何更改
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
4条回答 默认 最新
谛凌 2022-02-13 16:39关注把j=n改成j=n+1应该就行了
#include "stdio.h" int fun(int n) { int i, j = n+1, pd = 1; for (i = 2; i < n; i++) { if (j % i == 0) { pd = 0; } } if (pd == 1) { return j; } else return fun(j + 1); } void main() { int n; scanf("%d", &n); printf("%d", fun(n)); }本回答被题主选为最佳回答 , 对您是否有帮助呢?评论 打赏 举报 编辑记录解决 1无用