สมมติว่าเรามีอาร์เรย์ A และ B สองอาร์เรย์ อาร์เรย์ A มีองค์ประกอบ n รายการ อาร์เรย์ที่สอง B มีองค์ประกอบทั้งหมดของ A แต่จะถูกสับเปลี่ยนและนำองค์ประกอบหนึ่งออก เราต้องหาองค์ประกอบที่ขาดหายไป ดังนั้น ถ้า A =[4, 8, 1, 3, 7] และ B =[7, 4, 3, 1] ผลลัพธ์จะเป็น 8
ซึ่งสามารถแก้ไขได้โดยใช้เคล็ดลับ XOR การเกิดขึ้นรวมกันของแต่ละองค์ประกอบเป็นสองเท่า หนึ่งใน A และอีกองค์ประกอบใน B ยกเว้นองค์ประกอบเดียวซึ่งมีการเกิดขึ้นเพียงครั้งเดียวใน A ดังที่เราทราบ x XOR x =0 ดังนั้นหากเราทำ XOR ในองค์ประกอบของทั้งสอง อาร์เรย์ ผลลัพธ์จะเป็นตัวเลขที่หายไป
ตัวอย่าง
#include<iostream>
using namespace std;
int FindMissingElement(int A[], int B[], int n) {
int min_element = 0;
for (int i = 0; i < n; i++)
min_element = min_element ^ A[i];
for (int i = 0; i < n - 1; i++)
min_element = min_element ^ B[i];
return min_element;
}
int main() {
int A[] = {4, 8, 1, 3, 7};
int B[] = {7, 4, 3, 1};
int n = sizeof(A) / sizeof(A[0]);
cout << "Missing element: " << FindMissingElement(A, B, n);
} ผลลัพธ์
Missing element: 8