算法训练营day52,204. 计数质数

204. 计数质数

给定整数 n ,返回 所有小于非负整数 n 的质数的数量 。

示例 1:

输入:n = 10
输出:4
解释:小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 。

示例 2:

输入:n = 0
输出:0

示例 3:

输入:n = 1
输出:0

提示:

  • 0 <= n <= 5 * 106

//采用埃筛法解析

爱拉陶斯芬筛法,简称埃氏筛或爱氏筛。要得到自然数n以内的全部素数,必须把不大于根号n的所有素数的倍数剔除,剩下的就是素数。先用2去筛,即把2留下,把2的倍数剔除掉;再用下一个质数,也就是3筛,把3留下,把3的倍数剔除掉;接下去用下一个质数5筛,把5留下,把5的倍数剔除掉;不断重复下去......。

func countPrimes(n int) int {

  count := 0

  nums := make([]int, n)

  for i := 2; i < n; i++ {

    if nums[i] == 0 {

      count++

     //剔除素数倍数

      for j := 2 * i; j < n; j += i {

        nums[j] = 1

      }

    }

  }

  return count

}

相关推荐

  1. 算法训练day52,204. 计数质数

    2024-05-14 15:58:04       31 阅读
  2. 算法训练Day15

    2024-05-14 15:58:04       60 阅读
  3. 算法训练Day23

    2024-05-14 15:58:04       67 阅读
  4. 算法训练Day24

    2024-05-14 15:58:04       62 阅读
  5. 算法训练Day25

    2024-05-14 15:58:04       61 阅读
  6. 算法训练Day32

    2024-05-14 15:58:04       61 阅读
  7. 算法训练Day29

    2024-05-14 15:58:04       59 阅读
  8. 算法训练Day37

    2024-05-14 15:58:04       53 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-14 15:58:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-14 15:58:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-05-14 15:58:04       82 阅读
  4. Python语言-面向对象

    2024-05-14 15:58:04       91 阅读

热门阅读

  1. Spring AOP切面实现为mapper层指定方法入参字段赋值

    2024-05-14 15:58:04       31 阅读
  2. 如何隐藏一个元素的滚动条

    2024-05-14 15:58:04       26 阅读
  3. 【sql】复习题

    2024-05-14 15:58:04       26 阅读
  4. 策略模式实战

    2024-05-14 15:58:04       28 阅读
  5. 学习嵌入式开发必须掌握的基础硬件知识

    2024-05-14 15:58:04       35 阅读