Sobes.tech
Назад к вопросам
Senior
1

Лайвкодинг: есть массив чисел от 1 до 10, нужно возвести их в квадрат, распараллелив вычисления в трёх потоках (воркерах). Количество воркеров вынести в константу. Для каждого числа выводить ID воркера, который его обрабатывает.

Компании, где спрашивали
Магнум

Ответ от нейросети

sobes.tech AI

go package main

import ( "fmt" "sync" )

const workerCount = 3

func worker(id int, jobs <-chan int, wg *sync.WaitGroup) { defer wg.Done() for num := range jobs { result := num * num fmt.Printf("Worker %d processed number %d: %d\n", id, num, result) } }

func main() { numbers := []int{1,2,3,4,5,6,7,8,9,10} jobs := make(chan int, len(numbers)) var wg sync.WaitGroup

// Запускаем воркеры
for i := 1; i <= workerCount; i++ {
	wg.Add(1)
	go worker(i, jobs, &wg)
}

// Отправляем числа на обработку
for _, num := range numbers {
	jobs <- num
}
close(jobs)

wg.Wait()

}


В этом примере создаётся канал `jobs`, в который отправляются числа от 1 до 10. Три воркера параллельно читают из канала, возводят число в квадрат и выводят ID воркера и результат. Количество воркеров задаётся константой `workerCount`.