Python-알고리즘 분석
알고리즘 분석
알고리즘의 효율성은 구현 전과 구현 후의 두 단계에서 분석 할 수 있습니다. 그들은 다음과 같습니다-
A Priori Analysis− 이것은 알고리즘의 이론적 분석입니다. 알고리즘의 효율성은 다른 모든 요소 (예 : 프로세서 속도)가 일정하며 구현에 영향을 미치지 않는다고 가정하여 측정됩니다.
A Posterior Analysis− 이것은 알고리즘에 대한 실증적 분석입니다. 선택한 알고리즘은 프로그래밍 언어를 사용하여 구현됩니다. 그런 다음 대상 컴퓨터 컴퓨터에서 실행됩니다. 이 분석에서는 필요한 실행 시간 및 공간과 같은 실제 통계가 수집됩니다.
알고리즘 복잡성
가정 X 알고리즘이고 n 입력 데이터의 크기, 알고리즘 X에서 사용하는 시간과 공간은 X의 효율성을 결정하는 두 가지 주요 요소입니다.
Time Factor − 시간은 정렬 알고리즘에서 비교와 같은 주요 작업의 수를 계산하여 측정됩니다.
Space Factor − 공간은 알고리즘에 필요한 최대 메모리 공간을 계산하여 측정됩니다.
알고리즘의 복잡성 f(n) 알고리즘에 필요한 실행 시간 및 / 또는 저장 공간을 제공합니다. n 입력 데이터의 크기로.
공간 복잡성
알고리즘의 공간 복잡성은 알고리즘의 수명주기에서 필요한 메모리 공간의 양을 나타냅니다. 알고리즘에 필요한 공간은 다음 두 구성 요소의 합과 같습니다.
문제의 크기와 무관 한 특정 데이터 및 변수를 저장하는 데 필요한 공간 인 고정 부분입니다. 예를 들어 사용 된 단순 변수 및 상수, 프로그램 크기 등
변수 부분은 문제의 크기에 따라 크기가 달라지는 변수에 필요한 공간입니다. 예를 들어 동적 메모리 할당, 재귀 스택 공간 등이 있습니다.
모든 알고리즘 P의 공간 복잡도 S (P)는 S (P) = C + SP (I)이며, 여기서 C는 고정 부분이고 S (I)는 인스턴스 특성 I에 따라 달라지는 알고리즘의 변수 부분입니다. 개념을 설명하려는 간단한 예입니다.
Algorithm: SUM(A, B)
Step 1 - START
Step 2 - C ← A + B + 10
Step 3 - Stop
여기에 세 개의 변수 A, B, C와 하나의 상수가 있습니다. 따라서 S (P) = 1 + 3. 이제 공간은 주어진 변수와 상수 유형의 데이터 유형에 따라 달라지며 그에 따라 곱해질 것입니다.
시간 복잡성
알고리즘의 시간 복잡도는 알고리즘이 완료 될 때까지 실행하는 데 필요한 시간을 나타냅니다. 시간 요구 사항은 숫자 함수 T (n)로 정의 할 수 있습니다. 여기서 T (n)은 각 단계가 일정한 시간을 소비하는 경우 단계 수로 측정 할 수 있습니다.
예를 들어, 두 개의 n 비트 정수를 더하면 n단계. 결과적으로 총 계산 시간은 T (n) = c ∗ n이며, 여기서 c는 두 비트를 더하는 데 걸린 시간입니다. 여기서 우리는 입력 크기가 증가함에 따라 T (n)이 선형 적으로 증가하는 것을 관찰합니다.