เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่รับสตริงและส่งคืนอักขระจากสตริงที่ปรากฏขึ้นเป็นจำนวนมากที่สุดเป็นครั้งที่สอง
สมมติว่าต่อไปนี้คืออาร์เรย์ของเรา –
const arr = [1, 34, 4, 3, 2, 1, 4, 6, 4, 6, 5, 3, 6, 6];
ดังนั้น อักขระที่ปรากฏบ่อยคือ −
6
แต่เราต้องการให้เอาท์พุตเป็นอักขระที่ใช้บ่อยที่สุดเป็นอันดับสอง เช่น
4
มาเขียนโค้ดสำหรับฟังก์ชันนี้กัน −
ตัวอย่าง
const arr = [1, 34, 4, 3, 2, 1, 4, 6, 4, 6, 5, 3, 6, 6];
const secondMostFrequent = arr => {
const map = arr.reduce((acc, val) => {
if(acc.has(val)){
acc.set(val, acc.get(val) + 1);
}else{
acc.set(val, 1);
};
return acc;
}, new Map);
const frequencyArray = Array.from(map);
return frequencyArray.sort((a, b) => {
return b[1] - a[1];
})[1][0];
};
console.log(secondMostFrequent(arr)); ผลลัพธ์
ต่อไปนี้เป็นผลลัพธ์ในคอนโซล -
4