C ++
 Computer >> コンピューター >  >> プログラミング >> C ++

C++での配列の2つのサブセットの可能な最大差


このチュートリアルでは、配列の2つのサブセットの可能な最大の違いを見つけるプログラムについて説明します

このために、いくつかのランダムな整数の1つまたは2つのインスタンスを含む配列が提供されます。私たちのタスクは、それらの合計の差が最大になり、サブセットに繰り返し数が含まれないように、その配列の2つのサブセットを作成することです。

#include <bits/stdc++.h>
using namespace std;
//finding maximum subset difference
int maxDiff(int arr[], int n) {
   int SubsetSum_1 = 0, SubsetSum_2 = 0;
   for (int i = 0; i <= n - 1; i++) {
      bool isSingleOccurance = true;
      for (int j = i + 1; j <= n - 1; j++) {
         if (arr[i] == arr[j]) {
            isSingleOccurance = false;
            arr[i] = arr[j] = 0;
            break;
         }
      }
      if (isSingleOccurance) {
         if (arr[i] > 0)
            SubsetSum_1 += arr[i];
         else
            SubsetSum_2 += arr[i];
      }
   }
   return abs(SubsetSum_1 - SubsetSum_2);
}
int main() {
   int arr[] = { 4, 2, -3, 3, -2, -2, 8 };
   int n = sizeof(arr) / sizeof(arr[0]);
   cout << "Maximum Difference = " << maxDiff(arr, n);
   return 0;
}

出力

Maximum Difference = 20

  1. C++で同じ順序を維持する2つの指定された配列からの最大配列

    問題の説明 2つの同じサイズの配列A[]とB[]が与えられます。タスクは、同じサイズの3番目の配列を形成することです。結果の配列には、両方の配列から最大n個の要素が含まれている必要があります。最初にA[]の要素を選択し、次に元の配列に表示されるのと同じ順序でB[]の要素を選択する必要があります。共通の要素がある場合は、res []に1つの要素のみが存在し、A []が優先される必要があります。 例 入力配列が-の場合 arr1[] = {9, 17, 2, 25, 6} arr2[] = {17, 4, 8, 10, 1} then final array is: {9, 17, 25, 8

  2. 2次元配列をC++関数に渡す

    C ++では、配列全体を引数として関数に渡すことはできません。ただし、インデックスなしで配列の名前を指定することにより、配列へのポインタを渡すことができます。 2D配列を関数に渡すには3つの方法があります- 2D配列の列のサイズを指定します void processArr(int a[][10]) {    // Do something } ポインタを含む配列を渡す void processArr(int *a[10]) {    // Do Something } // When callingint *array[10]; for(int i