打印素数的四种方法

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

素数的定义:

素数:即质数,除了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;
}


相关文章
|
28天前
|
人工智能 算法 C语言
编写函数isprime(int a),用来判断自变量a是否为素数,若是素数,函数返回整数1,否则返回0
通过上述代码和解释,我们实现了一个高效判断素数的C语言函数 `isprime`。该函数结合了基础判断和优化的循环逻辑,确保高效准确地判断给定整数是否为素数。希望本文能帮助你更好地理解和实现素数判断算法。
30 1
|
7月前
|
C语言
【C语言】输入一个数n,输出从n到n+100的范围内所有的素数,并统计素数的个数
【C语言】输入一个数n,输出从n到n+100的范围内所有的素数,并统计素数的个数
412 0
|
6月前
循环迭代判断\找质数——以每行8个的形式输出100-999内的质数
循环迭代判断\找质数——以每行8个的形式输出100-999内的质数
81 5
|
7月前
打印100~200之间的素数
打印100~200之间的素数
编写判断一个正整数是否为素数的函数
编写判断一个正整数是否为素数的函数
打印100到200之间的素数(函数方法)
打印100到200之间的素数(函数方法)
132 0
打印100到200之间的素数(函数方法)
打印出100-200之间素数及总个数(用math函数)
打印出100-200之间素数及总个数(用math函数)
123 0
打印出100-200之间素数及总个数(用math函数)
|
机器学习/深度学习 算法
算法:从键盘循环输入一个整数,判断是否是素数\质数
算法:从键盘循环输入一个整数,判断是否是素数\质数
|
Java
用Java编写的素数代码,判断两个数之间的素数的个数以及素数
用Java编写的素数代码,判断两个数之间的素数的个数以及素数。
156 0
|
算法 C语言
素数的判断方法
素数的判断方法
154 0

热门文章

最新文章