🔥5👍2
Задача. Merge sort
Реализуйте конкурентное решение
В качестве опорной точки можно взять эту последовательную реализацию:
#задача
Реализуйте конкурентное решение
merge sort
(сортировка слиянием), используя горутины и каналы.В качестве опорной точки можно взять эту последовательную реализацию:
package mainКод с решением будет завтра.
import "fmt"
func Merge(left, right [] int) [] int{
merged := make([] int, 0, len(left) + len(right))
for len(left) > 0 || len(right) > 0{
if len(left) == 0 {
return append(merged,right...)
}else if len(right) == 0 {
return append(merged,left...)
}else if left[0] < right[0] {
merged = append(merged, left[0])
left = left[1:]
}else{
merged = append(merged, right [0])
right = right[1:]
}
}
return merged
}
func MergeSort(data [] int) [] int {
if len(data) <= 1 {
return data
}
mid := len(data)/2
left := MergeSort(data[:mid])
right := MergeSort(data[mid:])
return Merge(left,right)
}
func main(){
data := [] int{9,4,3,6,1,2,10,5,7,8}
fmt.Printf("%v\n%v\n", data, MergeSort(data))
}
#задача
👍8🐳7
Ответ на «Merge sort»
Теперь нужно сделать так, чтобы
Операция
#задача
package mainВ начале при сортировке слиянием мы рекурсивно разделяем массив на
import "fmt"
func Merge(left, right [] int) [] int{
merged := make([] int, 0, len(left) + len(right))
for len(left) > 0 || len(right) > 0{
if len(left) == 0 {
return append(merged,right...)
}else if len(right) == 0 {
return append(merged,left...)
}else if left[0] < right[0] {
merged = append(merged, left[0])
left = left[1:]
}else{
merged = append(merged, right [0])
right = right[1:]
}
}
return merged
}
func MergeSort(data [] int) [] int {
if len(data) <= 1 {
return data
}
done := make(chan bool)
mid := len(data)/2
var left [] int
go func(){
left = MergeSort(data[:mid])
done <- true
}()
right := MergeSort(data[mid:])
<-done
return Merge(left,right)
}
func main(){
data := [] int{9,4,3,6,1,2,10,5,7,8}
fmt.Printf("%v\n%v\n", data, MergeSort(data))
}
right
и left
стороны и на строках 30-34 вызываем MergeSort
для обеих сторон.Теперь нужно сделать так, чтобы
Merge(left, right)
выполнялась после получения возвращаемых значений от обоих рекурсивных вызовов, то есть и left
и right
должны обновляться до того, как Merge(left, right)
сможет быть выполнена. Для этого на строке 26 мы вводим канал типа bool
и отправляем в него true
сразу после выполнения left = MergeSort(data[:mid]
(строка 32).Операция
<-done
блокирует код на строке 35 до инструкции Merge(left,right)
, чтобы она не продолжилась, пока горутина не завершится. После завершения горутины и получения true
в канале done
код переходит к инструкции Merge(left, right)
на строке 36.#задача
👍8❤🔥2🤯2🔥1
🔥8👍2👎1🤯1
Forwarded from 🤟 TechRocks: Тестирование QA
🔥6👏2😱2👍1👎1😁1
Может ли функция Go быть создана на лету и использоваться в качестве значений?
Anonymous Quiz
88%
Да
12%
Нет
👍4
Что из следующего не является булевым типом в Go?
Anonymous Quiz
3%
true
2%
false
78%
0
17%
Все вышеперечисленное.
👎5👍4😁2🍾2👏1
Что из следующего верно в отношении выражения lvalue в Go?
Anonymous Quiz
30%
Выражения, которые относятся к ячейке памяти, называются выражениями «lvalue».
11%
Значение lvalue может отображаться как в левой, так и в правой части задания.
25%
Переменные являются lvalues и поэтому могут отображаться в левой части задания.
34%
Все вышеперечисленное.
🤡15👍6
Какой вариант объявления переменной не скомпилируется?
Anonymous Quiz
18%
var p = 99
61%
var p := 99
7%
p := 99
14%
все варианты скомпилируются
👌7👍1
Ответ на «Какие есть способы достать данные из JSON?»
Тут можно либо демаршализовать (
Для всего этого используется
Тут можно либо демаршализовать (
Unmarshal
) JSON и разлить его данные в объект с фиксированной структурой. Либо можно залить данные в пустой интерфейс.Для всего этого используется
json.Unmarshal()
👍13😁6👏1
Ответ на «Что такое горутины и зачем они нужны?»
Горутина (
Они нужны, если нам параллельно требуется сделать несколько действий. Например, ваш скрипт должен опросить множество сторонних сервисов и поработать с ответом. А что делать, если некоторые из сервисов долго отвечают? Как говорится, семеро одного не ждут! Каждому по горутине, и тогда не придется ждать «отстающих».
Горутина (
goroutine
) — это функция, которая выполняется асинхронно. Чтобы запустить горутину нужно лишь написать что-то вроде этого:go someFunc(args…) {Весит одна горутина около 4кб. Так что, если у вас 4ГБ оперативной памяти, то можно одновременно запустить немало горутин 🙂
//тут действия
}()
Они нужны, если нам параллельно требуется сделать несколько действий. Например, ваш скрипт должен опросить множество сторонних сервисов и поработать с ответом. А что делать, если некоторые из сервисов долго отвечают? Как говорится, семеро одного не ждут! Каждому по горутине, и тогда не придется ждать «отстающих».
👍27
Что из следующего верно для инструкции цикла в Go?
Anonymous Quiz
19%
если условие доступно, то цикл выполняется до тех пор, пока условие истинно.
6%
если диапазон доступен, то для цикла выполняется для каждого элемента в диапазоне.
73%
оба вышеупомянутых.
2%
ни один из вышеперечисленных.
Ответ на «Расскажите об ООП в Golang»
Формально оно в Go есть, но не совсем в том виде, в каком оно есть в PHP или Java.
В Go мы создаем структуры (читайте «классы») с определенными полями (свойствами), и далее создаем «экземпляры» этих структур. Методы описываются отдельно, а не внутри структур.
Формально оно в Go есть, но не совсем в том виде, в каком оно есть в PHP или Java.
В Go мы создаем структуры (читайте «классы») с определенными полями (свойствами), и далее создаем «экземпляры» этих структур. Методы описываются отдельно, а не внутри структур.
👎25👍4
Ответ на «Если в функции есть return, обязательно ли она вернет то, что указано в return?»
Мы привыкли, что обычно, если код внутри функции добрался до return, то на выходе мы получим то, что стоит после return. Но в Go есть интересная особенность: если есть именованный выходной параметр (параметры), то функция вернет последнее его значение, несмотря на то, что написано в
Мы привыкли, что обычно, если код внутри функции добрался до return, то на выходе мы получим то, что стоит после return. Но в Go есть интересная особенность: если есть именованный выходной параметр (параметры), то функция вернет последнее его значение, несмотря на то, что написано в
return
.package main
import "fmt"
// Основной метод
func main() {
// функция возвращает два значения
m, d := calculator(105, 7)
fmt.Println("105 x 7 = ", m)
fmt.Println("105 / 7 = ", d)
}
// функция с именованными аргументами
func calculator(a, b int) (mul int, div int) {
defer func() {
mul = 95
div = 27
}()
// здесь простое назначение т.к. инициализация произошла выше
//функция вернет именно эти переменные
mul = a * b
div = a / b
// здесь у вас есть ключевое слово return
return 1, 2
}
Функция вернет в итоге: 95 и 27.👍21👎3😁1
В каком из следующих методов передачи параметров изменения, внесенные в параметр внутри функции, не влияют на аргумент?
Anonymous Quiz
66%
вызов по значению.
19%
вызов по ссылке
7%
оба вышеуказанные.
8%
ничего из вышеперечисленного.
💩19👍1
Что из следующего верно в отношении range в Go?
Anonymous Quiz
38%
Ключевое слово range используется для цикла для перебора элементов массива, среза, канала или карты.
6%
С массивом и срезами он возвращает индекс элемента как целое.
3%
С помощью карт он возвращает ключ следующей пары ключ-значение.
52%
Все вышеперечисленное.
👍1
🤡39🤣16👎1