Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

คู่ค่า XOR ขั้นต่ำใน C++


คำชี้แจงปัญหา

กำหนดอาร์เรย์ของจำนวนเต็ม ค้นหาคู่ในอาร์เรย์ที่มีค่า 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