DAA-최대 최소 문제

분할 정복 기법으로 해결할 수있는 간단한 문제를 생각해 보겠습니다.

문제 설명

알고리즘 분석의 Max-Min 문제는 배열에서 최대 값과 최소값을 찾는 것입니다.

해결책

주어진 배열에서 최대 및 최소 수를 찾으려면 numbers[] 크기 n, 다음 알고리즘을 사용할 수 있습니다. 먼저 우리는naive method 그리고 우리는 divide and conquer approach.

나이브 방법

Naïve 방법은 모든 문제를 해결하는 기본 방법입니다. 이 방법에서는 최대 및 최소 수를 별도로 찾을 수 있습니다. 최대 및 최소 수를 찾기 위해 다음과 같은 간단한 알고리즘을 사용할 수 있습니다.

Algorithm: Max-Min-Element (numbers[]) 
max := numbers[1] 
min := numbers[1] 

for i = 2 to n do 
   if numbers[i] > max then  
      max := numbers[i] 
   if numbers[i] < min then  
      min := numbers[i] 
return (max, min)

분석

Naive 방법의 비교 횟수는 다음과 같습니다. 2n - 2.

분할 및 정복 접근 방식을 사용하면 비교 횟수를 줄일 수 있습니다. 다음은 기술입니다.

접근 방식을 나누고 정복하십시오

이 접근 방식에서 어레이는 두 개의 절반으로 나뉩니다. 그런 다음 재귀 접근 방식을 사용하여 각 반쪽에서 최대 및 최소 숫자를 찾습니다. 나중에 각 절반의 최대 값 2 개와 각 절반의 최소값 2 개를 반환합니다.

이 주어진 문제에서 배열의 요소 수는 $ y-x + 1 $입니다. 여기서 y 보다 크거나 같음 x.

$ \ mathbf {\ mathit {Max-Min (x, y)}} $는 배열 $ \ mathbf {\ mathit {numbers [x ... y]}} $의 최대 값과 최소값을 반환합니다.

Algorithm: Max - Min(x, y) 
if y – x ≤ 1 then  
   return (max(numbers[x], numbers[y]), min((numbers[x], numbers[y])) 
else 
   (max1, min1):= maxmin(x, ⌊((x + y)/2)⌋) 
   (max2, min2):= maxmin(⌊((x + y)/2) + 1)⌋,y) 
return (max(max1, max2), min(min1, min2))

분석

허락하다 T(n) $ \ mathbf {\ mathit {Max-Min (x, y)}} $에 의해 수행 된 비교 수입니다. 여기서 요소 수는 $ n = y-x + 1 $입니다.

만약 T(n) 숫자를 나타내면 되풀이 관계는 다음과 같이 나타낼 수 있습니다.

$$ T (n) = \ begin {cases} T \ left (\ lfloor \ frac {n} {2} \ rfloor \ right) + T \ left (\ lceil \ frac {n} {2} \ rceil \ right ) +2 & for \ : n> 2 \\ 1 & for \ : n = 2 \\ 0 & for \ : n = 1 \ end {cases} $$

가정하자 n 힘의 형태입니다 2. 그 후,n = 2k 어디 k 재귀 트리의 높이입니다.

그래서,

$$ T (n) = 2.T (\ frac {n} {2}) + 2 = 2. \ left (\ begin {array} {c} 2.T (\ frac {n} {4}) + 2 \ end {array} \ right) + 2 ..... = \ frac {3n} {2}-2 $$

Naïve 방법에 비해 분할 및 정복 방식에서는 비교 횟수가 적습니다. 그러나 점근 표기법을 사용하면 두 접근 방식 모두 다음과 같이 표현됩니다.O(n).