พิจารณาว่าเรามีอาร์เรย์ A ซึ่งถูกจัดเรียง มีองค์ประกอบทั้งหมดปรากฏสองครั้ง แต่มีองค์ประกอบหนึ่งปรากฏเพียงครั้งเดียว เราต้องหาองค์ประกอบนั้น หากอาร์เรย์คือ [1, 1, 3, 3, 4, 4, 5, 6, 6, 7, 7, 9, 9] ดังนั้นองค์ประกอบเดียวคือ 5
เราจะใช้วิธีการค้นหาแบบไบนารีเพื่อแก้ปัญหานี้ องค์ประกอบทั้งหมดก่อนองค์ประกอบเดียวมีการเกิดขึ้นครั้งแรกที่ดัชนี 0, 2, 4, … และเกิดขึ้นครั้งแรกที่ดัชนี 1, 3, 5, ... แต่หลังจากองค์ประกอบเดียว การเกิดขึ้นทั้งหมดของตัวเลขแรกจะเป็นดัชนีคี่ และ องค์ประกอบที่สองจะอยู่ที่ตำแหน่งดัชนีเท่ากัน
ก่อนอื่นให้หาค่ากลางของดัชนี mid ถ้า mid เป็นเลขคู่ ให้เปรียบเทียบ A[mid] กับ A[mid + 1] หากทั้งคู่เหมือนกัน ให้ไปทางซ้ายหรือขวาตามต้องการ มิฉะนั้น เมื่อ mid เป็นเลขคี่ ให้เปรียบเทียบ A[mid] และ A[mid – 1] หากเหมือนกัน ให้ไปทางซ้ายหรือขวาตามต้องการ
ตัวอย่าง
#include<iostream> using namespace std; void findSingleElement(int *arr, int left, int right) { if (left > right) return; if (left==right) { cout << "The required element is: "<< arr[left]; return; } int mid = (left + right) / 2; if (mid%2 == 0) { if (arr[mid] == arr[mid+1]) findSingleElement(arr, mid+2, right); else findSingleElement(arr, left, mid); }else{ if (arr[mid] == arr[mid-1]) findSingleElement(arr, mid+1, right); else findSingleElement(arr, left, mid-1); } } int main() { int arr[] = {1, 1, 3, 3, 4, 4, 5, 6, 6, 7, 7, 9, 9}; int len = sizeof(arr)/sizeof(arr[0]); findSingleElement(arr, 0, len-1); }
ผลลัพธ์
The required element is: 5