Как объединить два отсортированных массива в один отсортированный массив

«Как объединить два отсортированных массива в один отсортированный массив» — вопрос из категории Golang, который задают на 23% собеседований Golang Разработчик. Ниже — развёрнутый ответ с разбором ключевых моментов.

Ответ

Для объединения двух отсортированных массивов можно использовать алгоритм слияния, аналогичный 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 - длины массивов. Алгоритм эффективен, так как проходит по каждому массиву только один раз.