✿✿323 2022-02-13 16:23 采纳率: 83.3%
浏览 56
已结题

要求函数返回比形参大的最小的素数,但我这样调用,j永远等于n,如何更改

#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));
}

  • 写回答

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));
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 2月21日
  • 已采纳回答 2月13日
  • 创建了问题 2月13日