Computer >> 컴퓨터 >  >> 프로그램 작성 >> C++

C++의 최소 XOR 값 쌍

<시간/>

문제 설명

주어진 정수 배열. 배열에서 최소 XOR 값을 갖는 쌍 찾기

예시

If arr[] = {10, 20, 30, 40} then minimum value pair will be 20
and 30 as (20 ^ 30) = 10.
(10 ^ 20) = 30
(10 ^ 30) = 20
(10 ^ 40) = 34
(20 ^ 30) = 10
(20 ^ 40) = 60
(30 ^ 40) = 54

알고리즘

  • 주어진 배열의 모든 쌍을 생성하고 해당 값을 XOR 계산
  • 최소 XOR 값 반환

예시

#include <bits/stdc++.h>
using namespace std;
int getMinValue(int *arr, int n) {
   int minValue = INT_MAX;
   for (int i = 0; i < n; ++i) {
      for (int j = i + 1; j < n; ++j) {
         minValue = min(minValue, arr[i] ^ arr[j]);
      }
   }
   return minValue;
}
int main() {
   int arr[] = {10, 20, 30, 40};
   int n = sizeof(arr) / sizeof(arr[0]);
   cout << "Minimum value = " << getMinValue(arr, n) << endl;
   return 0;
}

위의 프로그램을 컴파일하고 실행할 때. 다음 출력을 생성합니다 -

출력

Minimum value = 10