สมมติว่าเรามีอาร์เรย์ A จากอาร์เรย์นั้น เราต้องเลือกสองคู่ (a, b) และ (c, d) โดยที่ ab =cd ให้อาร์เรย์ A =[3, 4, 7, 1, 2, 9, 8] คู่เอาต์พุตคือ (4, 2) และ (1, 8) เพื่อแก้ปัญหานี้ เราจะทำตามขั้นตอนเหล่านี้ -
- สำหรับ i :=0 ถึง n-1 ทำ
- สำหรับ j :=i + 1 ถึง n-1 ทำ
- รับสินค้า =arr[i] * arr[j]
- หากผลิตภัณฑ์ไม่มีอยู่ในตารางแฮช แสดงว่าแฮช[ผลิตภัณฑ์] :=(i, j)
- หากมีผลิตภัณฑ์อยู่ในตารางแฮช ให้พิมพ์องค์ประกอบก่อนหน้าและปัจจุบัน
- สำหรับ j :=i + 1 ถึง n-1 ทำ
ตัวอย่าง
#include <iostream>
#include <unordered_map>
using namespace std;
void displayPairs(int arr[], int n) {
bool found = false;
unordered_map<int, pair < int, int > > Hash;
for (int i=0; i<n; i++) {
for (int j=i+1; j<n; j++) {
int prod = arr[i]*arr[j];
if (Hash.find(prod) == Hash.end())
Hash[prod] = make_pair(i,j);
else{
pair<int,int> pp = Hash[prod];
cout << "(" << arr[pp.first] << ", " << arr[pp.second] << ") and (" << arr[i]<<", "<<arr[j] << ")"<<endl; found = true;
}
}
}
if (found == false)
cout << "No pairs have Found" << endl;
}
int main() {
int arr[] = {1, 2, 3, 4, 5, 6, 7, 8};
int n = sizeof(arr)/sizeof(int);
displayPairs(arr, n);
} ผลลัพธ์
(1, 6) and (2, 3) (1, 8) and (2, 4) (2, 6) and (3, 4) (3, 8) and (4, 6)