algorithm
Сложность алгоритма
Поиск…
замечания
Все алгоритмы - это список шагов для решения проблемы. Каждый шаг имеет зависимости от некоторого набора предыдущих шагов или начала алгоритма. Небольшая проблема может выглядеть следующим образом:
Эта структура называется направленным ациклическим графом или DAG для краткости. Связи между каждым узлом в графике представляют зависимости в порядке операций, а на графике нет циклов.
Как происходят зависимости? Возьмем, к примеру, следующий код:
total = 0
for(i = 1; i < 10; i++)
total = total + i
В этом psuedocode каждая итерация цикла for зависит от результата предыдущей итерации, потому что мы используем значение, вычисленное в предыдущей итерации в этой следующей итерации. DAG для этого кода может выглядеть так:
Если вы понимаете это представление алгоритмов, вы можете использовать его для понимания сложности алгоритма с точки зрения работы и диапазона.
Работа
Работа - это фактическое количество операций, которые необходимо выполнить для достижения цели алгоритма для заданного размера ввода n
.
пядь
Span иногда называют критическим путем и представляет собой наименьшее количество шагов, которые должен выполнить алгоритм для достижения цели алгоритма.
На следующем рисунке показан график, показывающий различия между работой и интервалом в нашем образце DAG.
Работа - это количество узлов на графике в целом. Это представлено графиком слева выше. Пролет - это критический путь или самый длинный путь от начала до конца. Когда работа может быть выполнена параллельно, желтые выделенные узлы справа представляют диапазон, минимальное количество шагов требуется. Когда работа должна выполняться серийно, пролет такой же, как и работа.
Как работу, так и диапазон можно оценивать независимо с точки зрения анализа. Скорость алгоритма определяется диапазоном. Объем требуемой вычислительной мощности определяется работой.
Обозначение Big-Theta
В отличие от нотации Big-O, которая представляет собой только верхнюю границу времени работы для некоторого алгоритма, Big-Theta является плотной границей; как верхняя, так и нижняя граница. Плотная привязка точнее, но сложнее вычислить.
Обозначение Big-Theta симметрично: f(x) = Ө(g(x)) <=> g(x) = Ө(f(x))
Интуитивно понятный способ понять это состоит в том, что f(x) = Ө(g(x))
означает, что графики f (x) и g (x) растут с той же скоростью или что графики «ведут себя» аналогично для больших достаточно значений х.
Полное математическое выражение нотации Большого тета выглядит следующим образом:
Ө (f (x)) = {g: N 0 -> R и c 1 , c 2 , n 0 > 0, где c 1 <abs (g (n) / f (n)), для любого n> n 0, а абс - абсолютное значение}
Пример
Если алгоритм для ввода n
42n^2 + 25n + 4
операций, мы говорим, что O(n^2)
, но также O(n^3)
и O(n^100)
. Однако это Ө(n^2)
и это не Ө(n^3)
, Ө(n^4)
и т. Д. Алгоритм Ө(f(n))
также O(f(n))
, но не наоборот!
Формальное математическое определение
Ө(g(x))
- множество функций.
Ө(g(x)) = {f(x) such that there exist positive constants c1, c2, N such that 0 <= c1*g(x) <= f(x) <= c2*g(x) for all x > N}
Поскольку Ө(g(x))
является множеством, мы могли бы написать f(x) ∈ Ө(g(x))
чтобы указать, что f(x)
является членом Ө(g(x))
. Вместо этого мы обычно будем писать f(x) = Ө(g(x))
чтобы выразить одно и то же понятие - это общий путь.
Всякий раз, когда Ө(g(x))
появляется в формуле, мы интерпретируем ее как стоящую за какую-то анонимную функцию, которую мы не хотим называть. Например, уравнение T(n) = T(n/2) + Ө(n)
означает T(n) = T(n/2) + f(n)
где f(n)
- функция из множества Ө(n)
.
Пусть f
и g
- две функции, определенные на некотором подмножестве вещественных чисел. Запишем f(x) = Ө(g(x))
как x->infinity
тогда и только тогда, когда существуют положительные константы K
и L
и вещественное число x0
такое, что выполнено:
K|g(x)| <= f(x) <= L|g(x)|
для всех x >= x0
.
Определение равно:
f(x) = O(g(x)) and f(x) = Ω(g(x))
Метод, который использует ограничения
если limit(x->infinity) f(x)/g(x) = c ∈ (0,∞)
т. е. предел существует и положителен, то f(x) = Ө(g(x))
Общие классы сложности
название | нотация | n = 10 | n = 100 |
---|---|---|---|
постоянная | Ө (1) | 1 | 1 |
логарифмический | Ө (журнал (п)) | 3 | 7 |
линейный | Ө (п) | 10 | 100 |
Linearithmic | Ө (п * журнала (п)) | 30 | 700 |
квадратный | Ө (п ^ 2) | 100 | 10 000 |
экспоненциальный | Ө (2 ^ п) | 1 024 | 1.267650e + 30 |
Факториал | Ө (п!) | 3 628 800 | 9.332622e + 157 |
Обозначение Big-Omega
Ω-обозначение используется для асимптотической нижней границы.
Формальное определение
Пусть f(n)
и g(n)
- две функции, определенные на множестве положительных вещественных чисел. Запишем f(n) = Ω(g(n))
если существуют положительные константы c
и n0
такие, что:
0 ≤ cg(n) ≤ f(n) for all n ≥ n0
.
Заметки
f(n) = Ω(g(n))
означает, что f(n)
растет асимптотически не медленнее g(n)
. Также можно сказать о Ω(g(n))
когда анализа алгоритма недостаточно для утверждения о Θ(g(n))
или / и O(g(n))
.
Из определений обозначений следует теорема:
Для двух любых функций f(n)
и g(n)
имеем f(n) = Ө(g(n))
тогда и только тогда, когда f(n) = O(g(n)) and f(n) = Ω(g(n))
.
Графически Ω-обозначение может быть представлено следующим образом:
Например, пусть f(n) = 3n^2 + 5n - 4
. Тогда f(n) = Ω(n^2)
. Это также верно f(n) = Ω(n)
или даже f(n) = Ω(1)
.
Другой пример для решения алгоритма идеального совпадения: если число вершин нечетное, тогда выведите «Нет идеального соответствия», в противном случае попробуйте все возможные сопоставления.
Мы хотели бы сказать, что алгоритм требует экспоненциального времени, но на самом деле вы не можете доказать нижнюю границу Ω(n^2)
используя обычное определение Ω
поскольку алгоритм работает в линейном времени для n нечетных. Мы должны вместо этого определить f(n)=Ω(g(n))
, сказав для некоторой константы c>0
, f(n)≥ cg(n)
для бесконечного числа n
. Это дает хорошее соответствие между верхней и нижней границами: f(n)=Ω(g(n))
если f(n) != o(g(n))
.
Рекомендации
Формальное определение и теорема взяты из книги «Томас Х. Кормен, Чарльз Э. Лейзерсон, Рональд Л. Ривест, Клиффорд Штайн. Введение в алгоритмы».
Сравнение асимптотических обозначений
Пусть f(n)
и g(n)
- две функции, определенные на множестве положительных вещественных чисел, c, c1, c2, n0
- положительные вещественные константы.
Асимптотические обозначения могут быть представлены на диаграмме Венна следующим образом:
связи
Томас Х. Кормен, Чарльз Э. Лейзерсон, Рональд Л. Ривест, Клиффорд Штайн. Введение в алгоритмы.