Sobes.tech
Back to questions
Middle
4

Задача: объединить два отсортированных слайса с уникальными значениями в один отсортированный слайс с уникальными значениями

Companies where asked
YadroYadro

Answer from AI

sobes.tech AI

Для объединения двух отсортированных слайсов с уникальными значениями в один отсортированный слайс с уникальными значениями можно использовать алгоритм слияния, похожий на этап слияния в сортировке слиянием.

Пример на Go:

func mergeUnique(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 if a[i] > b[j] {
            result = append(result, b[j])
            j++
        } else { // a[i] == b[j], добавляем один раз
            result = append(result, a[i])
            i++
            j++
        }
    }

    // Добавляем оставшиеся элементы
    for i < len(a) {
        result = append(result, a[i])
        i++
    }
    for j < len(b) {
        result = append(result, b[j])
        j++
    }

    return result
}

Этот код проходит по обоим слайсам, сравнивает текущие элементы и добавляет меньший в результат. Если элементы равны, добавляет один и продвигает оба индекса, чтобы избежать дубликатов. В итоге получается отсортированный слайс с уникальными значениями.