Sobes.tech
Назад к вопросам
Junior — Middle
76

Каким образом можно слить два отсортированных массива в один, сохранив порядок элементов?

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

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

sobes.tech AI

Для слияния двух отсортированных массивов в один отсортированный можно использовать алгоритм слияния, похожий на тот, что применяется в сортировке слиянием (merge sort). Идея в том, чтобы одновременно пройти по обоим массивам, сравнивая текущие элементы, и добавлять меньший из них в результирующий массив.

Пример на 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 — размеры исходных массивов.