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

网站建设用什么科目如何做视频门户网站

网站建设用什么科目,如何做视频门户网站,无锡做网站中企动力,网站建设互联网推广题目 使用 Go 语言统计 0-200000的数字中,哪些是素数? 思路 两种方法: 单循环遍历 1-200000 数字,并判断是否是素数。 使用了 Goroutine 和通道实现并发: 通过创建两个通道 intChan 和 primeChan,以及一…

题目

使用 Go 语言统计 0-200000的数字中,哪些是素数?

思路

两种方法:

  1. 单循环遍历 1-200000 数字,并判断是否是素数。

  2. 使用了 Goroutine 和通道实现并发:

    • 通过创建两个通道 intChanprimeChan,以及一个 sync.WaitGroup 来协调 Goroutine 的执行。

    • 然后,启动三个 Goroutine:

      • InputIntChan:向 intChan 通道中写入整数数据。
      • PrimeCompute:从 intChan 通道中读取整数数据,并判断是否为素数,将素数写入 primeChan 通道。
      • readPrimeChan:从 primeChan 通道中读取素数数据并输出。

      最后,使用 sync.WaitGroup 等待所有 Goroutine 执行完毕。

代码实现

单循环实现

package mainimport ("fmt""math""time"
)func main() {start := time.Now().Unix() // 记录开始时间primeChan := make(chan int, 2000000) // 创建一个缓冲大小为2000000的素数通道for i := 0; i <= 200000; i++ { // 判断从0到200000的整数是否为素数if isPrime(i) { // 如果是素数primeChan <- i // 写入素数通道}}end := time.Now().Unix() // 记录结束时间fmt.Println("总耗时时间:", end-start) // 输出总耗时时间
}// 判断一个整数是否为素数
func isPrime(n int) bool {if n <= 1 {return false}for i := 2; i <= int(math.Sqrt(float64(n))); i++ { // 只需遍历到sqrt(n)即可,减少计算量if n%i == 0 {return false}}return true
}

Goroutine 和通道实现

好的,以下是给代码加上注释后的版本:

package mainimport ("fmt""math""strconv""sync"
)func main() {var wg sync.WaitGroupwg.Add(3)intChan := make(chan int, 1000)      // 创建一个缓冲大小为1000的整数型通道primeChan := make(chan int, 2000000) // 创建一个缓冲大小为2000000的整数型通道go InputIntChan(intChan, &wg) // 启动写入整数的协程go PrimeCompute(intChan, primeChan, &wg) // 启动计算素数并写入素数通道的协程go readIntChan(primeChan, &wg) // 启动读取素数并输出的协程wg.Wait() // 等待所有协程结束
}// 判断一个整数是否为素数
func isPrime(n int) bool {if n <= 1 {return false}for i := 2; i <= int(math.Sqrt(float64(n))); i++ { // 只需遍历到sqrt(n)即可,减少计算量if n%i == 0 {return false}}return true
}// 往通道中写入整数
func InputIntChan(intChan chan<- int, wg *sync.WaitGroup) {for i := 0; i <= 200000; i++ { // 写入200000个整数intChan <- i // 写入整数通道fmt.Println("写入Int通道==" + strconv.Itoa(i))}close(intChan) // 写入完成,关闭通道wg.Done()      // 协程结束,减少计数器
}// 判断整数是否为素数,并往素数通道中写入素数
func PrimeCompute(intChan <-chan int, primeChan chan<- int, wg *sync.WaitGroup) {for i := range intChan { // 循环判断每个整数是否为素数if isPrime(i) {primeChan <- i // 如果是素数,往素数通道中写入素数}}close(primeChan) // 计算完毕,关闭素数通道wg.Done()        // 协程结束,减少计数器
}// 从素数通道中读取素数并输出
func readIntChan(primeChan <-chan int, wg *sync.WaitGroup) {for i := range primeChan { // 循环读取素数通道中的素数fmt.Println("从通道中读取素数==" + strconv.Itoa(i))}wg.Done() // 协程结束,减少计数器
}

优化思路

创造多个协程处理写入读取通道

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

相关文章:

  • 返利网网站怎么做做企业网站需要的人
  • 深圳腾网站建设嘉定区做网站
  • 兰州做网站的公司淄博招聘网
  • 正规的网站建设工作室网络公司经营范围能写建材吗
  • 大名做网站注册德国网站域名
  • 大气 网站源码河北百度推广seo
  • 六安商业网站建设费用wordpress rewirte
  • 电子政务门户网站建设方案东莞网站建设时间
  • 网站在线答题怎么做电子商务网站建设评价
  • wordpress上图片不显示seo推广的特点有
  • 百度建设公司网站修改wordpress文章id
  • 哪个网站做初中作业网页设计心得体会500
  • 建设自己的企业网站需要什么设计网站开发方案流程
  • 网站建设马鞍山美食网站开发背景
  • asp网站如何发布服装生产erp管理软件
  • 手机网站怎么做才适合优化做网站微信群
  • wordpress多站点不显示cn域名做网站
  • 阿里巴巴网站建设的功能定位百度投流
  • 图片展示网站搭建北京的网站建设公司哪家好
  • 做电商网站php开发的流程吉隆网站建设
  • 吉林建设公司网站工业设计作品
  • 长沙毕业设计代做网站价格wordpress新闻快讯插件
  • 网站下载的app删除了怎么找到网站 建设 申请
  • wordpress安装到网站吗青岛开发区建设局网站
  • 绵阳网站排名监理证查询网
  • 宿州建设银行网站夹江网站建设
  • 怎么在百度上创建网站新乡手机网站建设官网
  • 运营网站要多少费用好的wordpress企业模板
  • 如何注册一个网站域名网站页面怎么优化
  • wordpress页脚怎么修改seo友情链接是什么