>  기사  >  백엔드 개발  >  배열의 역수를 계산하기 위해 병합 정렬 알고리즘을 사용하여 작성된 C/C++ 프로그램

배열의 역수를 계산하기 위해 병합 정렬 알고리즘을 사용하여 작성된 C/C++ 프로그램

PHPz
PHPz앞으로
2023-08-25 19:33:28995검색

배열의 역수를 계산하기 위해 병합 정렬 알고리즘을 사용하여 작성된 C/C++ 프로그램

배열의 역 표현. 배열을 정렬된 형식으로 변환하는 데 필요한 변경 횟수입니다. 배열이 이미 정렬되어 있으면 반전이 0번 필요하지만, 다른 경우에는 배열이 반전되면 최대 반전 횟수가 달성됩니다.

이 문제를 해결하기 위해 병합 정렬 방법을 따라 시간 복잡도를 줄이고 분할 정복 알고리즘을 사용하겠습니다.

Input

A sequence of numbers. (1, 5, 6, 4, 20).

Output

숫자를 오름차순으로 정렬하는 데 필요한 반전 횟수입니다.

Here the number of inversions are 2.
First inversion: (1, 5, 4, 6, 20)
Second inversion: (1, 4, 5, 6, 20)

Algorithm

merge(array, tempArray, left, mid, right)

Input - 왼쪽, 오른쪽 및 중간 인덱스가 병합된 두 개의 배열입니다.

Output - 정렬된 순서로 배열을 병합합니다.

Begin
   i := left, j := mid, k := right
   count := 0
   while i <= mid -1 and j <= right, do
      if array[i] <= array[j], then
         tempArray[k] := array[i]
         increase i and k by 1
      else
         tempArray[k] := array[j]
         increase j and k by 1
         count := count + (mid - i)
   done
   while left part of the array has some extra element, do
      tempArray[k] := array[i]
      increase i and k by 1
   done
   while right part of the array has some extra element, do
      tempArray[k] := array[j]
      increase j and k by 1
   done
   return count
End

mergeSort(array, tempArray, left, right)

입력 - 배열과 임시 배열이 주어지면 배열의 왼쪽 및 오른쪽 인덱스.

출력 - 정렬 후 역순으로 정렬된 쌍의 수입니다.

Begin
   count := 0
   if right > left, then
      mid := (right + left)/2
      count := mergeSort(array, tempArray, left, mid)
      count := count + mergeSort(array, tempArray, mid+1, right)
      count := count + merge(array, tempArray, left, mid+1, right)
   return count
End

실시간 시연

#include <iostream>
using namespace std;
int merge(int arr[], int temp[], int left, int mid, int right) {
   int i, j, k;
   int count = 0;
   i = left; //i to locate first array location
   j = mid; //i to locate second array location
   k = left; //i to locate merged array location
   while ((i <= mid - 1) && (j <= right)) {
      if (arr[i] <= arr[j]){ //when left item is less than right item
      temp[k++] = arr[i++];
      } else {
         temp[k++] = arr[j++];
         count += (mid - i); //find how many convertion is performed
      }
   }
   while (i <= mid - 1) //if first list has remaining item, add them in the list
      temp[k++] = arr[i++];
   while (j <= right) //if second list has remaining item, add them in the list
      temp[k++] = arr[j++];
   for (i=left; i <= right; i++)
      arr[i] = temp[i]; //store temp Array to main array
   return count;
}
int mergeSort(int arr[], int temp[], int left, int right){
   int mid, count = 0;
   if (right > left) {
      mid = (right + left)/2; //find mid index of the array
      count = mergeSort(arr, temp, left, mid); //merge sort left sub array
      count += mergeSort(arr, temp, mid+1, right); //merge sort right sub array
      count += merge(arr, temp, left, mid+1, right); //merge two sub arrays
   }
   return count;
}
int arrInversion(int arr[], int n) {
   int temp[n];
   return mergeSort(arr, temp, 0, n - 1);
}
int main() {
   int arr[] = {1, 5, 6, 4, 20};
   int n = 5;
   cout << "Number of inversions are "<< arrInversion(arr, n);
}

출력

Number of inversions are 2

위 내용은 배열의 역수를 계산하기 위해 병합 정렬 알고리즘을 사용하여 작성된 C/C++ 프로그램의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 tutorialspoint.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제