golang编程题

1、开启100个协程,顺序打印1-1000,并保证协程号为1的,打印尾数也是1

Go 复制代码
package main

import "fmt"

const (
	routineNum = 100
	numMax     = 1000
)

func main() {
	s := make(chan struct{})
	channels := make(map[int]chan int, 100)
	for i := 1; i <= routineNum; i++ {
		channels[i] = make(chan int)
	}
	for i := 1; i <= routineNum; i++ {
		go func(idx int) {
			for {
				num := <-channels[idx]
				fmt.Printf("chan id:[%d],num:[%d]\n", idx, num)
				s <- struct{}{}
			}

		}(i)
	}

	for j := 1; j <= numMax; j++ {
		idx := j % routineNum //0~99
		if idx == 0 {
			idx = routineNum
		}
		channels[idx] <- j
		<-s
	}
	return
}

2、3个goroutinue交替打印abc10次

Go 复制代码
package main

import (
	"fmt"
	"sync"
)

func main() {
	chan1 := make(chan struct{})
	chan2 := make(chan struct{})
	chan3 := make(chan struct{})
	var wg sync.WaitGroup
	wg.Add(3)

	go func() {
		defer wg.Done()
		for i := 0; i < 10; i++ {
			<-chan1
			fmt.Println("a")
			chan2 <- struct{}{}
		}
		<-chan1
	}()
	go func() {
		defer wg.Done()

		for i := 0; i < 10; i++ {
			<-chan2
			fmt.Println("b")
			chan3 <- struct{}{}
		}

	}()
	go func() {
		defer wg.Done()

		for i := 0; i < 10; i++ {
			<-chan3
			fmt.Println("c")
			chan1 <- struct{}{}
		}
	}()
	chan1 <- struct{}{}
	wg.Wait()

	close(chan1)
	close(chan2)
	close(chan3)
}

3、用不超过10个goroutinue打印不重复的打印slice中100个元素

4、用2个协程交替打印奇偶数

相关推荐
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言