0

0

Go语言实现埃拉托斯特尼筛法:一个修正后的版本

花韻仙語

花韻仙語

发布时间:2025-07-22 17:22:01

|

453人浏览过

|

来源于php中文网

原创

go语言实现埃拉托斯特尼筛法:一个修正后的版本

本文旨在帮助开发者理解并实现埃拉托斯特尼筛法,用于高效地找出一定范围内的所有质数。我们将分析一个存在问题的Go语言实现,找出并修复其中的错误,并提供一个可正确运行的版本,以便读者更好地掌握该算法的原理和实现细节。

埃拉托斯特尼筛法简介

埃拉托斯特尼筛法是一种古老而高效的算法,用于找出给定范围内的所有质数。其基本思想是从2开始,将每个质数的倍数标记为合数(非质数),直到达到指定的范围。剩余未被标记的数字即为质数。

问题分析与修复

原始代码存在一个关键错误,导致筛选结果不正确。错误位于sieve函数内部的内层循环的起始条件:

for j := i; j < len(numCopy); j++ {
  if numCopy[j] % numCopy[i] != 0 || j == i {
   sievedNumbers = append(sievedNumbers, numCopy[j])
  }
}

该循环从j = i开始,这意味着它会跳过numCopy[i]之前的元素,从而导致某些合数没有被正确地排除。例如,当i = 0时,numCopy[i]为2,循环应该从j = 0开始,检查所有元素是否能被2整除。

立即学习go语言免费学习笔记(深入)”;

正确的做法是将内层循环的起始条件改为j = 0:

Batch GPT
Batch GPT

使用AI批量处理数据、自动执行任务

下载
for j := 0; j < len(numCopy); j++ {
  if numCopy[j] % numCopy[i] != 0 || j == i {
   sievedNumbers = append(sievedNumbers, numCopy[j])
  }
}

修正后的代码

以下是修正后的Go语言代码:

package main

import "fmt"

func main() {
    primes := sieve(makeNumbers(29))
    fmt.Printf("%v\n", primes)
}

func makeNumbers(n int) []int {
    numbers := make([]int, n-1)
    for i := 0; i < len(numbers); i++ {
        numbers[i] = i + 2
    }
    return numbers
}

func sieve(numbers []int) []int {
    numCopy := numbers
    max := numbers[len(numbers)-1]
    sievedNumbers := make([]int, 0)
    for i := 0; i < len(numCopy) && numCopy[i]*numCopy[i] <= max; i++ {
        for j := 0; j < len(numCopy); j++ {
            if numCopy[j]%numCopy[i] != 0 || j == i {
                sievedNumbers = append(sievedNumbers, numCopy[j])
            }
        }
        numCopy = sievedNumbers
        sievedNumbers = make([]int, 0)
    }
    return numCopy
}

代码解释

  1. makeNumbers(n int) []int: 此函数生成一个包含从2到n的整数切片。
  2. sieve(numbers []int) []int: 此函数实现了埃拉托斯特尼筛法。
    • numCopy := numbers: 创建一个numbers的副本,避免修改原始切片。
    • max := numbers[len(numbers)-1]: 获取numbers切片中的最大值。
    • sievedNumbers := make([]int, 0): 创建一个空切片,用于存储筛选后的数字。
    • 外层循环遍历numCopy,直到当前数字的平方大于max。
    • 内层循环遍历numCopy,检查每个数字是否能被numCopy[i]整除。如果不能整除,或者当前数字就是numCopy[i]本身(j == i),则将该数字添加到sievedNumbers切片中。
    • 循环结束后,将sievedNumbers赋值给numCopy,并清空sievedNumbers,为下一轮筛选做准备。
  3. main(): 主函数调用makeNumbers生成数字切片,然后调用sieve进行筛选,最后打印结果。

运行结果

运行修正后的代码,将得到以下输出:

[2 3 5 7 11 13 17 19 23 29]

这与预期结果一致,表明代码已成功修正。

注意事项与总结

  • 埃拉托斯特尼筛法的时间复杂度为O(n log log n),是一种非常高效的质数筛选算法。
  • 在实现该算法时,需要注意循环的起始条件,以确保所有合数都被正确地排除。
  • 可以使用更高级的数据结构,例如位图,来进一步优化算法的性能。
  • 该算法的空间复杂度取决于要筛选的数字范围。对于非常大的范围,可能需要考虑使用分段筛法来减少内存占用

通过本文的分析和修正,读者应该能够更好地理解和掌握埃拉托斯特尼筛法的原理和实现,并能够在自己的项目中应用该算法。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

522

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

48

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

190

2025.08.29

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

529

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

6

2025.12.22

Go中Type关键字的用法
Go中Type关键字的用法

Go中Type关键字的用法有定义新的类型别名或者创建新的结构体类型。本专题为大家提供Go相关的文章、下载、课程内容,供大家免费下载体验。

233

2023.09.06

go怎么实现链表
go怎么实现链表

go通过定义一个节点结构体、定义一个链表结构体、定义一些方法来操作链表、实现一个方法来删除链表中的一个节点和实现一个方法来打印链表中的所有节点的方法实现链表。

442

2023.09.25

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Rust 教程
Rust 教程

共28课时 | 4万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 2.1万人学习

Go 教程
Go 教程

共32课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号