점근 표기법 및 Apriori 분석
알고리즘 설계에서 알고리즘의 복잡도 분석은 필수 요소입니다. 주로 알고리즘 복잡성은 성능, 작동 속도, 속도와 관련이 있습니다.
알고리즘의 복잡성은 데이터 처리에 필요한 메모리 양과 처리 시간 측면에서 알고리즘의 효율성을 설명합니다.
알고리즘의 복잡성은 두 가지 관점에서 분석됩니다. Time 과 Space.
시간 복잡성
입력 크기 측면에서 알고리즘을 실행하는 데 필요한 시간을 설명하는 함수입니다. "시간"은 수행 된 메모리 액세스 수, 정수 간 비교 수, 내부 루프가 실행되는 횟수 또는 알고리즘이 소요되는 실시간 양과 관련된 다른 자연 단위를 의미 할 수 있습니다.
공간 복잡성
알고리즘에 대한 입력 크기 측면에서 알고리즘이 차지하는 메모리 양을 설명하는 함수입니다. 우리는 종종 입력 자체를 저장하는 데 필요한 메모리를 계산하지 않고 "추가"메모리가 필요하다고 말합니다. 다시 말하지만,이를 측정하기 위해 자연 (그러나 고정 길이) 단위를 사용합니다.
사용 된 공간이 최소화되고 명확하기 때문에 공간 복잡성은 때때로 무시되지만 때로는 시간만큼 중요한 문제가됩니다.
점근 표기법
알고리즘의 실행 시간은 명령어 세트, 프로세서 속도, 디스크 I / O 속도 등에 따라 달라집니다. 따라서 알고리즘의 효율성을 점근 적으로 추정합니다.
알고리즘의 시간 함수는 다음과 같이 표현됩니다. T(n), 어디 n 입력 크기입니다.
알고리즘의 복잡성을 나타 내기 위해 다양한 유형의 점근 표기법이 사용됩니다. 알고리즘의 실행 시간 복잡도를 계산하기 위해 다음 점근 표기법이 사용됩니다.
O − 빅 오
Ω − 빅 오메가
θ − 빅 세타
o − 리틀 오
ω − 리틀 오메가
O : 점근 상한
'O'(Big Oh)는 가장 일반적으로 사용되는 표기법입니다. 기능f(n) 표현할 수있는 순서입니다 g(n) 그건 O(g(n)), 양의 정수 값이있는 경우 n 같이 n0 및 양의 상수 c 그런-
$ n> n_ {0} $에 대해 $ f (n) \ leqslant cg (n) $ (모든 경우)
따라서 기능 g(n) 함수의 상한 f(n), 같이 g(n) 보다 빠르게 성장 f(n).
예
주어진 함수 $ f (n) = 4.n ^ 3 + 10.n ^ 2 + 5.n + 1 $를 생각해 봅시다.
$ g (n) = n ^ 3 $를 고려하면,
$ n> 2 $의 모든 값에 대해 $ f (n) \ leqslant 5.g (n) $
따라서 복잡성 f(n) $ O (g (n)) $, 즉 $ O (n ^ 3) $로 나타낼 수 있습니다.
Ω : 점근 하한
상수가있을 때 $ f (n) = \ Omega (g (n)) $라고 말합니다. c 충분히 큰 가치에 대해 $ f (n) \ geqslant cg (n) $ n. 여기n양의 정수입니다. 그것은 기능을 의미합니다g 함수의 하한입니다. f; 특정 값 이후n, f 아래로 가지 않을 것이다 g.
예
주어진 함수 $ f (n) = 4.n ^ 3 + 10.n ^ 2 + 5.n + 1 $를 생각해 봅시다.
$ n> 0 $의 모든 값에 대해 $ g (n) = n ^ 3 $, $ f (n) \ geqslant 4.g (n) $를 고려합니다.
따라서 복잡성 f(n) $ \ Omega (g (n)) $, 즉 $ \ Omega (n ^ 3) $로 나타낼 수 있습니다.
θ : 점근 타이트 바운드
상수가 존재할 때 $ f (n) = \ theta (g (n)) $라고 말합니다. c1 과 c2 충분히 큰 값에 대해 $ c_ {1} .g (n) \ leqslant f (n) \ leqslant c_ {2} .g (n) $ n. 여기n 양의 정수입니다.
이것은 기능을 의미합니다 g 기능에 대한 긴밀한 경계 f.
예
주어진 함수 $ f (n) = 4.n ^ 3 + 10.n ^ 2 + 5.n + 1 $를 생각해 봅시다.
모든 큰 값에 대해 $ g (n) = n ^ 3 $, $ 4.g (n) \ leqslant f (n) \ leqslant 5.g (n) $ 고려 n.
따라서 복잡성 f(n) $ \ theta (g (n)) $, 즉 $ \ theta (n ^ 3) $로 나타낼 수 있습니다.
O-표기법
에 의해 제공되는 점근 상한 O-notation점근 적으로 단단 할 수도 있고 아닐 수도 있습니다. 바운드 $ 2.n ^ 2 = O (n ^ 2) $는 점근 적으로 빡빡하지만 바운드 $ 2.n = O (n ^ 2) $는 그렇지 않습니다.
우리는 사용 o-notation 점근 적으로 빡빡하지 않은 상한을 나타냅니다.
우리는 공식적으로 정의합니다 o(g(n)) (n의 g의 little-oh) 세트로 f(n) = o(g(n)) 양의 상수 $ c> 0 $에 대해 $ n_ {0}> 0 $ 값이 존재합니다. $ 0 \ leqslant f (n) \ leqslant cg (n) $.
직관적으로 o-notation, 함수 f(n) 상대적으로 중요하지 않다 g(n) 같이 n무한대에 접근합니다. 그건,
$$ \ lim_ {n \ rightarrow \ infty} \ left (\ frac {f (n)} {g (n)} \ right) = 0 $$
예
동일한 함수 $ f (n) = 4.n ^ 3 + 10.n ^ 2 + 5.n + 1 $를 생각해 봅시다.
$ g (n) = n ^ {4} $를 고려하면,
$$ \ lim_ {n \ rightarrow \ infty} \ left (\ frac {4.n ^ 3 + 10.n ^ 2 + 5.n + 1} {n ^ 4} \ right) = 0 $$
따라서 복잡성 f(n) $ o (g (n)) $, 즉 $ o (n ^ 4) $로 나타낼 수 있습니다.
ω – 표기법
우리는 사용 ω-notation점근 적으로 빡빡하지 않은 하한을 나타냅니다. 그러나 공식적으로 우리는ω(g(n)) (n의 g의 작은 오메가) 세트로 f(n) = ω(g(n)) 양의 상수 C > 0 $ n_ {0}> 0 $, $ 0 \ leqslant cg (n) <f (n) $와 같은 값이 있습니다.
예를 들어 $ \ frac {n ^ 2} {2} = \ omega (n) $이지만 $ \ frac {n ^ 2} {2} \ neq \ omega (n ^ 2) $입니다. $ f (n) = \ omega (g (n)) $ 관계는 다음 제한이 있음을 의미합니다.
$$ \ lim_ {n \ rightarrow \ infty} \ left (\ frac {f (n)} {g (n)} \ right) = \ infty $$
그건, f(n) 상대적으로 임의로 커집니다 g(n) 같이 n 무한대에 접근합니다.
예
같은 함수 $ f (n) = 4.n ^ 3 + 10.n ^ 2 + 5.n + 1 $를 생각해 봅시다.
$ g (n) = n ^ 2 $를 고려하면,
$$ \ lim_ {n \ rightarrow \ infty} \ left (\ frac {4.n ^ 3 + 10.n ^ 2 + 5.n + 1} {n ^ 2} \ right) = \ infty $$
따라서 복잡성 f(n) $ o (g (n)) $, 즉 $ \ omega (n ^ 2) $로 나타낼 수 있습니다.
Apriori 및 Apostiari 분석
Apriori 분석은 특정 시스템에서 실행하기 전에 분석이 수행됨을 의미합니다. 이 분석은 이론적 모델을 사용하여 함수를 정의하는 단계입니다. 따라서 우리는 다른 메모리, 프로세서 및 컴파일러가있는 특정 시스템에서 실행하는 대신 알고리즘을보고 알고리즘의 시간 및 공간 복잡성을 결정합니다.
알고리즘의 Apostiari 분석은 알고리즘을 시스템에서 실행 한 후에 만 알고리즘을 분석하는 것을 의미합니다. 이는 시스템에 직접적으로 의존하며 시스템마다 변경됩니다.
업계에서는 소프트웨어가 일반적으로 업계에 존재하는 것과 다른 시스템에서 실행되는 익명의 사용자를 위해 만들어지기 때문에 Apostiari 분석을 수행 할 수 없습니다.
Apriori에서는 컴퓨터에서 컴퓨터로 바뀔 때 시간과 공간의 복잡성을 결정하기 위해 점근 표기법을 사용하는 이유입니다. 그러나 점근 적으로는 동일합니다.