打印素数的四种方法

简介: 打印素数的四种方法

素数的定义:

素数:即质数,除了1和它本身外,没有其他的约数。

代码实现:

方法一:试除法:判断i是否为素数:用[2, i)之间的每个数据去被i除,只要有一个可以被整除,则不是素数。

int main()
{
  int i = 0;
  int count = 0;
  // 外层循环用来获取100~200之间的所有数据,100肯定不是素数,因此i从101开始
  for (i = 101; i <= 200; i++)
  {
    //判断i是否为素数:用[2, i)之间的每个数据去被i除,只要有一个可以被整除,则不是素数
    int j = 0;
    for (j = 2; j < i; j++)
    {
      if (i % j == 0)
      {
        break;
      }
    }
    // 上述循环结束之后,如果j和i相等,说明[2, i)之间的所有数据都不能被i整除,则i为素数
    if (j == i)
    {
      count++;
      printf("%d ", i);
    }
  }
  printf("\ncount = %d\n", count);
  return 0;
}

方法二:将方法一进行优化,每拿到一个数据,只需要拿[2, i/2]区间内的数据即可,因为另一半数据可以通过前一半数据乘2获得。

int main()
{
  int i = 0;//
  int count = 0;
  for (i = 101; i <= 200; i++)
  {
    //判断i是否为素数
    //2->i-1
    int j = 0;
    for (j = 2; j <= i / 2; j++)
    {
      if (i % j == 0)
      {
        break;
      }
    }
    //...
    if (j > i / 2)
    {
      count++;
      printf("%d ", i);
    }
  }
  printf("\ncount = %d\n", count);
  return 0;
}

方法三:再进行一次优化,如果i能够被[2, sqrt(i)]之间的任意数据整除,则i不是素数

原因:如果 m 能被 2 ~ m-1 之间任一整数整除,其二个因子必定有一个小于或等于sqrt(m),另一个大于或等于 sqrt(m)。

int main()
{
  int i = 0;
  int count = 0;
  for (i = 101; i <= 200; i++)
  {
    //判断i是否为素数
    //2->i-1
    int j = 0;
    for (j = 2; j <= sqrt(i); j++)
    {
      if (i % j == 0)
      {
        break;
      }
    }
    //...
    if (j > sqrt(i))
    {
      count++;
      printf("%d ", i);
    }
  }
  printf("\ncount = %d\n", count);
  return 0;
}

方法四:实际上在操作时i不用从101逐渐递增到200,因为出了2和3之外,不会有两个连续相邻的数据同时为素数。

int main()
{
  int i = 0;
  int count = 0;
  for (i = 101; i <= 200; i += 2)
  {
    //判断i是否为素数
    //2->i-1
    int j = 0;
    for (j = 2; j <= sqrt(i); j++)
    {
      if (i % j == 0)
      {
        break;
      }
    }
    //...
    if (j > sqrt(i))
    {
      count++;
      printf("%d ", i);
    }
  }
  printf("\ncount = %d\n", count);
  return 0;
}


相关文章
|
6月前
|
C语言
【C语言】输入一个数n,输出从n到n+100的范围内所有的素数,并统计素数的个数
【C语言】输入一个数n,输出从n到n+100的范围内所有的素数,并统计素数的个数
326 0
|
6月前
|
存储 弹性计算 运维
打印斐波那契数列
【4月更文挑战第29天】
50 0
|
6月前
打印100~200之间的素数
打印100~200之间的素数
编写判断一个正整数是否为素数的函数
编写判断一个正整数是否为素数的函数
|
人工智能 Python
打印完全数
打印完全数
76 0
打印100到200之间的素数(函数方法)
打印100到200之间的素数(函数方法)
119 0
打印100到200之间的素数(函数方法)
打印 斐波那契数列
打印 斐波那契数列
90 0
打印出100-200之间素数及总个数(用math函数)
打印出100-200之间素数及总个数(用math函数)
119 0
打印出100-200之间素数及总个数(用math函数)
|
机器学习/深度学习 算法
算法:从键盘循环输入一个整数,判断是否是素数\质数
算法:从键盘循环输入一个整数,判断是否是素数\质数
|
算法 C语言
素数的判断方法
素数的判断方法
143 0