Ответ
Для объединения двух отсортированных массивов можно использовать алгоритм слияния, аналогичный merge-этапу в сортировке слиянием. В Go это можно реализовать так:
func mergeSortedArrays(a, b []int) []int {
result := make([]int, 0, len(a)+len(b))
i, j := 0, 0
for i < len(a) && j < len(b) {
if a[i] < b[j] {
result = append(result, a[i])
i++
} else {
result = append(result, b[j])
j++
}
}
// Добавляем оставшиеся элементы
result = append(result, a[i:]...)
result = append(result, b[j:]...)
return result
}
Сложность алгоритма - O(n+m), где n и m - длины массивов. Алгоритм эффективен, так как проходит по каждому массиву только один раз.