目次
入力
出力
Algorithm
merge(array, tempArray, left, middle, right)
mergeSort(array, tempArray, left, right)
ホームページ バックエンド開発 C++ 配列内の逆数を計算するためにマージ ソート アルゴリズムを使用して作成された C/C++ プログラム

配列内の逆数を計算するためにマージ ソート アルゴリズムを使用して作成された C/C++ プログラム

Aug 25, 2023 pm 07:33 PM
マージソート C/Cプログラム 逆序数

配列内の逆数を計算するためにマージ ソート アルゴリズムを使用して作成された C/C++ プログラム

配列の反転表現。配列をソートされた形式に変換するために必要な変更の数。配列がすでにソートされている場合、反転は 0 回必要ですが、その他の場合、配列が反転されると、反転の最大数が達成されます。

この問題を解決するために、マージ ソート方法に従って時間の複雑さを軽減し、分割統治アルゴリズムを使用します。

入力

A sequence of numbers. (1, 5, 6, 4, 20).
ログイン後にコピー

出力

数値を昇順に並べ替えるのに必要な反転回数。

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, middle, right)

Input - マージされた 2 つの配列、左、右と真ん中のインデックス。

出力 - 配列はソートされた順序でマージされます。

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)

Input - 配列と一時配列が与えられた場合、配列の左と右のインデックス。

出力 - ソート後の逆順のペアの数。

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 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

n番目のカタロニア語番号のC/C++プログラムは何ですか? n番目のカタロニア語番号のC/C++プログラムは何ですか? Sep 11, 2023 pm 10:33 PM

n番目のカタロニア語番号のC/C++プログラムは何ですか?

配列内の逆数を計算するためにマージ ソート アルゴリズムを使用して作成された C/C++ プログラム 配列内の逆数を計算するためにマージ ソート アルゴリズムを使用して作成された C/C++ プログラム Aug 25, 2023 pm 07:33 PM

配列内の逆数を計算するためにマージ ソート アルゴリズムを使用して作成された C/C++ プログラム

PHPでマージソートを実装する方法 PHPでマージソートを実装する方法 Oct 21, 2022 am 09:30 AM

PHPでマージソートを実装する方法

PHPのマージソートアルゴリズムの詳細説明 PHPのマージソートアルゴリズムの詳細説明 Jul 08, 2023 pm 05:03 PM

PHPのマージソートアルゴリズムの詳細説明

C# でマージ ソート アルゴリズムを実装する方法 C# でマージ ソート アルゴリズムを実装する方法 Sep 19, 2023 am 09:45 AM

C# でマージ ソート アルゴリズムを実装する方法

分割統治法を使用して PHP にマージソートアルゴリズムを実装し、ソート効率を向上させるにはどうすればよいですか? 分割統治法を使用して PHP にマージソートアルゴリズムを実装し、ソート効率を向上させるにはどうすればよいですか? Sep 19, 2023 pm 02:10 PM

分割統治法を使用して PHP にマージソートアルゴリズムを実装し、ソート効率を向上させるにはどうすればよいですか?

Javaを使用してマージソートアルゴリズムを実装する方法 Javaを使用してマージソートアルゴリズムを実装する方法 Sep 19, 2023 am 11:33 AM

Javaを使用してマージソートアルゴリズムを実装する方法

C/C++ プログラムをプリプロセッサ コードに変換する C/C++ プログラムをプリプロセッサ コードに変換する Sep 11, 2023 pm 04:21 PM

C/C++ プログラムをプリプロセッサ コードに変換する

See all articles