สมมติว่าเรามีรายการที่เชื่อมโยงสามรายการ เราต้องหาองค์ประกอบทั่วไปทั้งหมดที่มีอยู่ในรายการที่เชื่อมโยงทั้งสามนี้ สมมติว่ารายการเหล่านี้คือ [10, 12, 15, 20, 25], [10, 12, 13, 15] และ [10, 12, 15, 24, 25, 26] ดังนั้นองค์ประกอบทั่วไปในสามรายการนี้คือ 10 , 12 และ 15.
เราจะใช้เทคนิคการแฮชเพื่อแก้ปัญหานี้ เพื่อแก้ปัญหานี้ เราต้องทำตามขั้นตอนเหล่านี้ -
-
สร้างตารางแฮชที่ว่างเปล่า และผ่านแต่ละองค์ประกอบในตารางแรก และแทรกองค์ประกอบ และทำเครื่องหมายความถี่เป็น 1
-
วนซ้ำผ่านรายการที่เชื่อมโยงที่สอง จากนั้นหากความถี่ปัจจุบันเป็น 1 สำหรับองค์ประกอบ ให้ทำเป็น 2
-
วนซ้ำผ่านรายการที่เชื่อมโยงที่สาม จากนั้นหากความถี่ปัจจุบันเป็น 2 สำหรับองค์ประกอบ ให้ทำเป็น 3
-
ตอนนี้วนซ้ำในรายการแรกอีกครั้งเพื่อตรวจสอบความถี่ขององค์ประกอบ หากมีองค์ประกอบบางอย่างที่มีความถี่เป็น 3 ให้พิมพ์องค์ประกอบนั้นและไปต่อ
ตัวอย่าง
#include<iostream>
#include<cmath>
#include<unordered_map>
using namespace std;
class Node {
public:
int data;
Node* next;
};
void addNode(Node** start, int data) {
Node* newNode = new Node;
newNode->data = data;
newNode->next = (*start);
(*start) = newNode;
}
void findCommonValues(Node* list1, Node* list2, Node* list3) {
unordered_map<int, int> hash;
Node* p = list1;
while (p != NULL) {
hash[p->data] = 1;
p = p->next;
}
Node* q = list2;
while (q != NULL) {
if (hash.find(q->data) != hash.end()) hash[q->data] = 2;
q = q->next;
}
Node* r = list3;
while (r != NULL) {
if (hash.find(r->data) != hash.end() && hash[r->data] == 2)
hash[r->data] = 3;
r = r->next;
}
for (auto x : hash) {
if (x.second == 3)
cout << x.first << " ";
}
}
int main() {
Node* list1 = NULL;
addNode(&list1, 10);
addNode(&list1, 12);
addNode(&list1, 15);
addNode(&list1, 20);
addNode(&list1, 25);
Node* list2 = NULL;
addNode(&list2, 10);
addNode(&list2, 12);
addNode(&list2, 13);
addNode(&list2, 15);
Node* list3 = NULL;
addNode(&list3, 10);
addNode(&list3, 12);
addNode(&list3, 15);
addNode(&list3, 24);
addNode(&list3, 25);
addNode(&list3, 26);
cout << "Common elements are: ";
findCommonValues(list1, list2, list3);
} ผลลัพธ์
Common elements are: 10 12 15