Изменения

Перейти к: навигация, поиск

Поиск k-ой порядковой статистики в двух массивах

781 байт добавлено, 18:18, 13 апреля 2015
Варианты решения
=== Наивное решение за <tex>O(n + m)</tex> ===
Сольем два массива и просто возьмем элемент с индексом <tex>k</tex>. Сливание будет выполнено за O(n + m).
=== Чуть менее наивное решение за <tex>O(k)</tex> ===
Будем использовать два указателя, с помощью которых сможем обойти массивы не сливая их. Поставим указатели на начало каждого из массивов. Будем увеличивать на единицу тот из них, который указывает на меньший элемент. После <tex>k</tex>-ого добавления сравним элементы, на которых стоят указатели. Меньший из них и будет ответом. Таким образом мы получим <tex>k</tex>-ый элемент за <tex>O(k)</tex> шагов.
577
правок

Навигация