Go语言的素数筛
package main import ( "fmt" "runtime" "runtime/debug" ) // 返回生成自然数序列的管道: 2, 3, 4, ... func GenerateNatural() chan int { ch := make(chan int) go func() { for i := 2; ; i++ { ch <- i } }() return ch } // 管道过滤器: 删除能被素数整除的数 func PrimeFilter(in <-chan int, prime int) chan int { out := make(chan int) go func() { for { if i := <-in; i%prime != 0 { out <- i } } }() return out } // 素数筛: 菊花链模型 func main() { runtime.GOMAXPROCS(1) debug.SetMaxThreads(5) ch := GenerateNatural() // 自然数序列: 2, 3, 4, ... for i := 0; i < 100; i++ { prime := <-ch // 新出现的素数 fmt.Printf("%v: %v\n", i+1, prime) ch = PrimeFilter(ch, prime) // 基于新素数构造的过滤器 } }
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。