Назад к вопросам
Wildberries
Junior — Middle
76
Каким образом можно слить два отсортированных массива в один, сохранив порядок элементов?
Компании, где спрашивали
Ответ от нейросети
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 — размеры исходных массивов.