Поиск в матрице — различия между версиями
Kolchanov (обсуждение | вклад) |
Kolchanov (обсуждение | вклад) |
||
Строка 2: | Строка 2: | ||
|definition = Задана отсортированная двумерная матрица, состоящая из n строк и m столбцов. Необходимо найти расположение указанного элемента в матрице или определить, что данный элемент в матрице отсутствует. | |definition = Задана отсортированная двумерная матрица, состоящая из n строк и m столбцов. Необходимо найти расположение указанного элемента в матрице или определить, что данный элемент в матрице отсутствует. | ||
}} | }} | ||
− | |||
− | |||
{{Определение | {{Определение | ||
Строка 9: | Строка 7: | ||
|definition=Отсортированная матрица - матрица, для которой выполнено следующее условие: <tex> a[row][col] \le a[row + 1][col], a[row][col] \le a[row][col + 1] </tex> | |definition=Отсортированная матрица - матрица, для которой выполнено следующее условие: <tex> a[row][col] \le a[row + 1][col], a[row][col] \le a[row][col + 1] </tex> | ||
}} | }} | ||
+ | |||
+ | |||
+ | [[Файл:sorted_matrix_example.png|320px|thumb|right|Пример отсортированной матрицы]] | ||
+ | |||
== Решение за O(n<tex>\cdot</tex>m) == | == Решение за O(n<tex>\cdot</tex>m) == | ||
Для начала рассмотрим наивный алгоритм поиска элемента. В каждой строке исходной матрицы запускаем линейный поиск, если находим элемент, то возвращаем его координаты <tex>(row, col)</tex>. Время работы — <tex>O(n \cdot m)</tex>. | Для начала рассмотрим наивный алгоритм поиска элемента. В каждой строке исходной матрицы запускаем линейный поиск, если находим элемент, то возвращаем его координаты <tex>(row, col)</tex>. Время работы — <tex>O(n \cdot m)</tex>. | ||
Строка 27: | Строка 29: | ||
− | == Код == | + | === Код === |
'''if''' (target < a[0][0] || target > a[N-1][N-1]) | '''if''' (target < a[0][0] || target > a[N-1][N-1]) |
Версия 14:31, 23 января 2016
Задача: |
Задана отсортированная двумерная матрица, состоящая из n строк и m столбцов. Необходимо найти расположение указанного элемента в матрице или определить, что данный элемент в матрице отсутствует. |
Определение: |
Отсортированная матрица - матрица, для которой выполнено следующее условие: |
Содержание
Решение за O(n m)
Для начала рассмотрим наивный алгоритм поиска элемента. В каждой строке исходной матрицы запускаем линейный поиск, если находим элемент, то возвращаем его координаты
. Время работы — .
Решение за O(n log(m))
Данный способ решения использует наивное решение за двоичного поиска. Для этого в каждой строке запускается двоичный поиск. Время работы — .
, улучшенное с помощьюЗамечание
Время работы может быть улучшено до
. Для этого необходимо модифицировать алгоритм так, чтобы в том случае, если столбцов больше чем строк, он бы запускал двоичный поиск по строкам, если строк больше — наоборот.
Решение за O(n + m)
В данном решении мы начинаем поиск из правого верхнего угла и движемся к искомому элементу. Идея алгоритма в том, что если текущий элемент меньше необходимого, то мы сдвигаемся на одну строку вниз. Если он больше, то мы сдвигаемся на одну колонку вправо.
Код
if (target < a[0][0] || target > a[N-1][N-1]) return false; row = 0; col = N-1; while (row <= N-1 && col >= 0) { if (a[row][col] < target) row++; else if (a[row][col] > target) col--; else return true; return false;
Оценка времени работы
Очевидно, что во время работы указатель сдвигается максимум на n строк и m столбцов. В этом случае время работы составляет
.