当前位置: 首页 > news >正文

属于c2c网站的有哪几个c2c电子商务平台举例

属于c2c网站的有哪几个,c2c电子商务平台举例,白城市住房建设局网站,山东食品行业网站模板描述 给定整数 n ,返回 所有小于非负整数 n 的质数的数量 。 示例 1: 输入:n 10 输出:4 解释:小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 。示例 2: 输入:n 0 输出:0示例 3…

描述

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

示例 1:

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

示例 2:

输入:n = 0
输出:0

示例 3:

输入:n = 1
输出:0

提示:

  • 0 <= n <= 5 * 10^{6}

 超时代码

class Solution:def countPrimes(self, n: int) -> int:num=0for i in range(2,n):for j in range(2,int(math.sqrt(i))+1):if i%j == 0:breakelse:num+=1return num         

优化后的埃氏筛(
 来自Leecod题解powcai)

class Solution:  def countPrimes(self, n: int) -> int:  # 定义一个函数 countPrimes,接受一个整数 n 作为参数,并返回一个整数if n < 2:  # 如果 n 小于 2,直接返回 0,因为 2 是最小的素数,n 小于 2 不会有素数return 0  # 创建一个长度为 n 的列表 isPrimes,初始化为全 1,表示所有数都是潜在的素数isPrimes = [1] * n  # 将索引 0 和 1 对应的位置设为 0,因为 0 和 1 不是素数isPrimes[0] = isPrimes[1] = 0  # 遍历从 2 到 sqrt(n) 的整数(包含 sqrt(n)),这是埃拉托色尼筛法的优化步骤for i in range(2, int(math.sqrt(n)) + 1):  if isPrimes[i] == 1:  # 如果 i 是素数(即 isPrimes[i] 为 1)# 将 i 的所有倍数(从 i*i 开始,到 n 结束,步长为 i)标记为非素数(设为 0)isPrimes[i * i:n:i] = [0] * len(isPrimes[i * i:n:i])  # 返回 isPrimes 列表中所有素数的个数(即值为 1 的元素的个数)return sum(isPrimes)  

效率提升的关键在于埃拉托斯特尼筛法,简称埃式筛,也叫厄拉多塞筛法:

要得到自然数 n 以内的全部质数,必须把不大于 根号n 的所有质数的倍数剔除,剩下的就是质数。

基本思路

埃氏筛的基本思路是:

  1. 从2开始,依次标记每个素数的倍数为非素数。
  2. 重复上述步骤,直到处理完所有小于等于√n的数。

具体步骤

  1. 初始化

    • 创建一个布尔列表 isPrimes,长度为 n,初始化为全 TrueisPrimes[i] 表示数字 i 是否是素数。
    • isPrimes[0]isPrimes[1] 设为 False,因为0和1不是素数。
  2. 标记非素数

    • 2 开始遍历,每次找到一个未被标记为非素数的数字 i,将其所有倍数(从 i*i 开始)标记为非素数。
    • 之所以从 i*i 开始,是因为所有小于 i*i 的倍数在之前已经被处理过。
  3. 优化

    • 遍历的终止条件为 i <= √n,因为如果 i > √n,则 i 的所有倍数都已经在之前被标记。

优化思路的详细解释

为什么从 i*i 开始标记?

当你处理到某个数 i 时,所有比 i*i 小的 i 的倍数都已经在之前的步骤中被标记。例如,当处理 i = 3 时,3 的倍数 69 等已经在处理 i = 2 时被标记了。因此,从 i*i 开始标记可以避免重复操作,提高效率。

为什么只需处理到 √n

对于一个合数 n,它必然可以表示为两个整数的乘积,即 n = a * b。如果 ab 都大于 √n,则 a * b > n,这不可能。因此,在 √n 之后,只需要考虑标记较小因子的倍数。

 

http://www.yayakq.cn/news/834639/

相关文章:

  • 花生壳做网站缺点网站建设项目如何敏捷
  • 有没有在网上做ps赚钱的网站脚底长了像水泡一样的东西很痒什么原因
  • 东莞产品网站建设网页设计基础只是
  • 怎么建设音乐试听网站网站开发drupal
  • 网络营销之网站建设在哪找做调查赚钱的网站好
  • 桂林网站建设费用wordpress中英文网站
  • 品牌网站建设d小蝌蚪wordpress主题怎么上传
  • 用dw做淘客网站的步骤网站引导页在线做
  • 深圳建设工程造价管理站深圳网站建设 外包合作
  • 重启 iis 中的网站logo免费生成器
  • 深圳网站建设计爱站网挖掘词
  • 外贸订单网站推广企业装修展厅公司
  • 公司官方网站一般什么公司做wordpress显示产品类别
  • 佛山品牌网站建设报价应税服务网站开发开票
  • 怎样进入当地建设局网站网站标题间隔符
  • 怎么建立一个个人网站开发直播平台
  • 厦门网站建设awordpress 同类文章
  • 叫别人做网站要多久网站建设公司推荐金石下拉网络
  • 四川中成煤炭建设集团网站网页制作工具安其制作方式分 可以分为
  • 深圳自适应网站建设价格网站备案 管局审核 需要多长时间
  • app门户网站api导入wordpress
  • 京东商城的网站怎么建设的哪有专做飞织鞋面的网站
  • 四川宜宾网站建设网页qq登录保护在哪里
  • 广告 网站举例网站主题设计特色
  • 四省网站建设想给公司做个网站怎么做的
  • devexpress 网站开发网络服务平台有哪些
  • 开封企业网站建设什么是网络设计冗余设计
  • 分类门户网站开发团队wordpress评论ip
  • 和各大网站做视频的工作0基础1小时网站建设教程
  • 电影网站开发apiapp开发入门基础教程