C++の配列で極小値を見つける
この問題を解決するために、二分探索のようなロジックに従います。中央の要素が左右の要素よりも小さい場合は中央に戻ります。そうでない場合は、左側の要素よりも大きい場合は左側に極小値があり、右側の要素よりも大きい場合はそこにあります。右側の極小値になります。同じタスクを実行して、正確な極小値を見つけます。
例
#include<iostream> using namespace std; int localMinima(int arr[], int left, int right, int n) { int mid = left + (right - left)/2; if ((mid == 0 || arr[mid-1] > arr[mid]) && (mid == n-1 || arr[mid+1] > arr[mid])) return mid; else if (mid > 0 && arr[mid-1] < arr[mid]) return localMinima(arr, left, (mid -1), n); return localMinima(arr, (mid + 1), right, n); } int findLocalMinima(int arr[], int n) { return localMinima(arr, 0, n-1, n); } int main() { int arr[] = {9, 6, 3, 14, 5, 7, 4}; int n = sizeof(arr)/sizeof(arr[0]); cout << "Local minima is: " << arr[findLocalMinima(arr, n)]; }
出力
Local minima is: 3
-
C++で指定された配列の要素の階乗のGCDを検索します
N個の要素を持つ配列Aがあるとします。配列のすべての要素の階乗のGCDを見つける必要があります。要素が{3、4、8、6}であるとすると、階乗のGCDは6です。ここでトリックを確認します。 2つの数値のGCDは、両方の数値を除算する最大の数値であるため、2つの数値の階乗のGCDは、最小の数値自体の階乗の値です。だから3の公約数!と5! 3です! =6. 例 #include <iostream> using namespace std; long fact(int n){ if(n <= 1) return
-
C ++関数からローカル配列を返す方法は?
ローカル配列は、関数呼び出し後にメモリに存在しない可能性があるため、C++関数から直接返すことはできません。これを解決する方法は、関数で静的配列を使用することです。静的配列の存続期間はプログラム全体であるため、上記の問題なしにC++関数から簡単に返すことができます。 これを実証するプログラムは次のとおりです。 例 #include <iostream> using namespace std; int *retArray() { static int arr[10]; for(int i = 0; i<10; i++) {