天之蔲 发表于 2020-11-10 23:55:15

萌新求助,这个循环看的有点头晕,有没有大佬帮忙解释一下y

#include<stdio.h>
#include<math.h>
int main()
{
    int start, end, i, k, m, flag = 1, h = 0;
    do
    {
      printf("Input START and END:");
      scanf("%d%d", &start, &end);
    } while (!(start > 0 && start < end));
    printf("......... prime table(%d-%d).........\n", start, end);
    for (m = start; m <= end; m++)
    {
      k = sqrt(m);
      for (i = 2; i <= k; i++)
            if (m % i == 0)
            {
                flag = 0;
                break;
            }
      if (flag)
      {
            printf("%-4d", m);
            h++;
            if (h % 10 == 0)
                printf("\n");
      }
      flag = 1;
    }
    printf("\nThe total is %d", h);
    return 0;
}

昨非 发表于 2020-11-11 00:03:07

这是啥代码,素数判断?

昨非 发表于 2020-11-11 00:06:48

m 只需被 2 ~ 根号m 之间的每一个整数去除就可以判断为素数。如果 m 不能被 2 ~根号m间任一整数整除,m 必定是素数。例如判别 17 是是否为素数,只需使 17 被 2~4 之间的每一个整数去除,由于都不能整除,可以判定 17 是素数。
#include<stdio.h>
#include<math.h>
int main()
{
        int start, end, i, k, m, flag = 1, h = 0;
        do
        {
                printf("Input START and END:");
                scanf("%d%d", &start, &end);
        } while (!(start > 0 && start < end));
        printf("......... prime table(%d-%d).........\n", start, end);
        for (m = start; m <= end; m++)    //m从start遍历到end
        {
                k = sqrt(m);    //k等于根号m
                for (i = 2; i <= k; i++)    //遍历2到k,看能否整除
                        if (m % i == 0)
                        {
                                flag = 0;//如果可以flag变化
                                break;
                        }
                if (flag)   //这里对应不能整除的情况,也就是素数,打印出来
                {
                        printf("%-4d", m);
                        h++;
                        if (h % 10 == 0)
                                printf("\n");
                }
                flag = 1;
        }
        printf("\nThe total is %d", h);
        return 0;
}

天之蔲 发表于 2020-11-11 00:35:47

昨非 发表于 2020-11-11 00:06
m 只需被 2 ~ 根号m 之间的每一个整数去除就可以判断为素数。如果 m 不能被 2 ~根号m间任一整数整除,m...

大佬,那个flag在里面起到什么作用呀?

昨非 发表于 2020-11-11 00:50:24

天之蔲 发表于 2020-11-11 00:35
大佬,那个flag在里面起到什么作用呀?

标识作用,如果是素数就变化为0不是素数不变
最后根据是否为变化打印
满意的话记得设为最佳答案

天之蔲 发表于 2020-11-11 00:51:37

昨非 发表于 2020-11-11 00:03
这是啥代码,素数判断?

这个就是素数判断,然后将取值范围内的素数打印出来

天之蔲 发表于 2020-11-11 00:52:22

昨非 发表于 2020-11-11 00:50
标识作用,如果是素数就变化为0不是素数不变
最后根据是否为变化打印
满意的话记得设为最佳答案

好的,谢谢

昨非 发表于 2020-11-11 00:52:31

天之蔲 发表于 2020-11-11 00:51
这个就是素数判断,然后将取值范围内的素数打印出来

我知道,
页: [1]
查看完整版本: 萌新求助,这个循环看的有点头晕,有没有大佬帮忙解释一下y