Назад к вопросам
Yadro
Middle
3
Задача: объединить два отсортированных слайса с уникальными значениями в один отсортированный слайс с уникальными значениями
Компании, где спрашивали
Ответ от нейросети
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
}
Этот код проходит по обоим слайсам, сравнивает текущие элементы и добавляет меньший в результат. Если элементы равны, добавляет один и продвигает оба индекса, чтобы избежать дубликатов. В итоге получается отсортированный слайс с уникальными значениями.