ปัญหา
เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่รับอาร์เรย์ของตัวเลขสองอาร์เรย์ arr1 andarr2 เป็นอาร์กิวเมนต์แรกและอาร์กิวเมนต์ที่สอง
ฟังก์ชันของเราควรรวมองค์ประกอบของอาร์เรย์ทั้งสองนี้เข้าในอาร์เรย์ใหม่ และหากเมื่อผสานหรือก่อนที่จะรวมมีรายการที่ซ้ำกัน เราควรลบรายการที่ซ้ำกันส่วนเกินเพื่อให้มีเพียงสำเนาเดียวของแต่ละองค์ประกอบที่มีอยู่ในอาร์เรย์ที่ผสาน
ลำดับที่นี่ไม่สำคัญแต่ความถี่ขององค์ประกอบ (ซึ่งควรเป็น 1 สำหรับแต่ละองค์ประกอบ) มีความสำคัญ
ตัวอย่างเช่น หากอินพุตของฟังก์ชันคือ −
onst arr1 = [6, 5, 2, 1, 8]; const arr2 = [3, 4, 6, 8, 9];
จากนั้นผลลัพธ์ควรเป็น −
const output = [6, 5, 2, 1, 8, 3, 4, 9];
ตัวอย่าง
ต่อไปนี้เป็นรหัส -
const arr1 = [6, 5, 2, 1, 8];
const arr2 = [3, 4, 6, 8, 9];
const mergeAndRectify = (arr1 = [], arr2) => {
const { length: len1 } = arr1;
const { length: len2 } = arr2;
const res = [];
let curr = 0;
for(let i = 0; i < len1+len2; i++){
if(i >= len1){
curr = i - len1;
if(!res.includes(arr1[curr])){
res.push(arr1[curr]);
};
}else{
curr = i;
if(!res.includes(arr2[curr])){
res.push(arr2[curr]);
};
};
};
return res;
};
console.log(mergeAndRectify(arr1, arr2)); ผลลัพธ์
ต่อไปนี้เป็นเอาต์พุตคอนโซล -
[ 3, 4, 6, 8, 9, 5, 2, 1 ]