C++の配列内の各要素のSurpasserCountを検索します
1つの配列Aが与えられたと仮定します。その配列内の各要素の超過者の数を見つける必要があります。超過者は、現在の要素の配列の右側に存在するより大きな要素です。 A ={2、7、5、3、0、8、1}とすると、超過者は{4、1、1、1、2、0、0}であるため、2の右側には4つの数字があります。 4よりも多く、他の人にも同じルールがあります。解決策は非常に単純で、2つのネストされたループがあり、要素ごとに、超過者をカウントして、別の配列に格納します。
例
#include <iostream> using namespace std; void gerSurpassers(int arr[], int surpassers[], int n){ for(int i = 0; i<n; i++){ int count = 0; for(int j = i+1; j<n; j++){ if(arr[j] > arr[i]) count++; } surpassers[i] = count; } } void displayArray(int arr[], int n){ for(int i = 0; i<n; i++){ cout << arr[i] << " "; } cout << "\n"; } int main() { int arr[] = {2, 7, 5, 3, 0, 8, 1}; int n = sizeof(arr) / sizeof(arr[0]); int surpassers[n]; cout << "Elements :"; displayArray(arr, n); gerSurpassers(arr, surpassers, n); cout << "Surpassers:"; displayArray(surpassers, n); }
出力
Elements :2 7 5 3 0 8 1 Surpassers:4 1 1 1 2 0 0
-
配列内の反転をカウントするC++プログラム
カウント反転とは、配列をソートするために必要なスイッチの数を意味します。配列がソートされている場合、反転カウント=0。反転カウント=配列が逆の順序でソートされた場合の最大値。 配列内の反転をカウントするC++プログラムを開発しましょう。 アルゴリズム Begin Function CountInversionArray has arguments a[], n = number of elements. initialize counter c := 0 for i in range 0 to n-1, do &n
-
配列の最大要素を見つけるためのC++プログラム
配列には複数の要素が含まれており、配列内の最大の要素は他の要素よりも大きい要素です。 たとえば。 5 1 7 2 4 上記の配列では、7が最大の要素であり、インデックス2にあります。 配列の最大の要素を見つけるプログラムは次のとおりです。 例 #include <iostream> using namespace std; int main() { int a[] = {4, 9, 1, 3, 8}; int largest, i, pos; largest = a[0