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

C++の2n+1整数要素の配列で単一を検索します


この問題では、(2n + 1)個の整数値で構成される配列が与えられます。これらすべての値のうち、n個の要素が配列に2回表示され、配列には1つの要素しかありません。それは一度現れます。私たちのタスクは、2n+1個の整数要素の配列から単一を見つけることです。

問題を理解するために例を見てみましょう

入力

arr[] = {1, 3, 5, 6, 5, 1, 3}

出力

5

ソリューションアプローチ

この問題の簡単な解決策は、要素にカウンターを使用することです。要素が検出された場合は、その値と発生回数を保存します。この後、発生数=1のテーブル内の要素を検索します。より効率的なソリューション XORを使用します。ここでは、配列のすべての要素のXORを実行します。このXORは、2回出現するすべての要素を0にします。また、値が存在する要素は、出現回数が1である要素のみです。

これは、XORのプロパティが-

であるためです。
- a^a = 0
- a^0 = a

ソリューションの動作を説明するプログラム

#include <iostream>
using namespace std;
int findSingleValue(int arr[], int n) {
   int element = 0;
   for (int i = 0; i < n; i++)
      element = element ^ arr[i];
   return element;
}
int main() {
   int arr[] = { 1, 3, 5, 6, 5, 1, 3 };
   int n = sizeof(arr) / sizeof(arr[0]);
   cout<<"The element of the array with single occurrence is "<<findSingleValue(arr, n);
   return 0;
}

出力

The element of the array with single occurrence is 6

  1. 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

  2. 配列の最大要素を見つけるための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