เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่ใช้ตัวเลขสองอาร์เรย์ สมมติว่า arr1 และ arr2 ฟังก์ชันควรหาจุดตัดระหว่างองค์ประกอบของอาร์เรย์ นั่นคือองค์ประกอบที่ปรากฏในอาร์เรย์ทั้งสอง
เงื่อนไขเดียวคือถ้าเราพบองค์ประกอบหนึ่งก่อนหน้านี้ว่าตัดกัน เราไม่ควรพิจารณาองค์ประกอบนั้นอีกแม้ว่าจะปรากฏขึ้นอีกครั้งในอาร์เรย์ทั้งสอง
ตัวอย่างเช่น −
หากอาร์เรย์อินพุตเป็น −
const arr1 = [1, 5, 7, 3, 1]; const arr2 = [1, 7, 3, 1, 6];
จากนั้นอาร์เรย์เอาต์พุตควรเป็น −
const output = [1, 3, 7];
อย่างไรก็ตาม ลำดับนั้นไม่สำคัญ สิ่งที่สำคัญกว่านั้นคือไม่ต้องพิจารณาถึงทางแยกที่ซ้ำซากจำเจ
ตัวอย่าง
ต่อไปนี้เป็นรหัส -
const arr1 = [1, 5, 7, 3, 1];
const arr2 = [1, 7, 3, 1, 6];
const uniqueIntersection = (arr1, arr2) => {
const map = new Set();
const res = [];
arr1.forEach(el => map.add(el));
arr2.forEach(el => {
if (map.has(el)) {
res.push(el);
map.delete(el);
};
});
return res;
};
console.log(uniqueIntersection(arr1, arr2)); ผลลัพธ์
ต่อไปนี้เป็นผลลัพธ์บนคอนโซล -
[1, 7, 3]