เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่รับอาร์เรย์ของ Numbers ที่มีค่าบวกและค่าลบบางส่วน เราจำเป็นต้องตรวจสอบว่ามี subarray ในอาร์เรย์เดิมที่มีผลรวมสุทธิเป็น 0 หรือไม่
ฟังก์ชันของเราควรคืนค่าบูลีนบนพื้นฐานนี้
แนวทาง
วิธีการที่นี่เป็นเรื่องง่าย เราวนซ้ำในอาร์เรย์โดยใช้ for loop คำนวณผลรวมสะสมจนถึงองค์ประกอบเฉพาะนั้น และถ้าจุดใดที่ค่าสะสมกลายเป็น 0 หรือได้ค่าที่มันเคยได้รับมาก่อน ก็จะมีอาร์เรย์ย่อยที่มีผลรวม 0 อยู่ มิฉะนั้นจะมี nosubarray ที่มีผลรวมเป็น 0
ดังนั้น เรามาเขียนโค้ดสำหรับฟังก์ชันนี้กัน −
ตัวอย่าง
const arr = [4, 2, -1, 5, -2, -1, -2, -1, 4, -1, 5, -2, 3]; const zeroSum = arr => { const map = new Map(); let sum = 0; for(let i = 0; i < arr.length; i++){ sum += arr[i]; if(sum === 0 || map.get(sum)){ return true; }; map.set(sum, i); }; return false; }; console.log(zeroSum(arr));
ผลลัพธ์
ผลลัพธ์ในคอนโซลจะเป็น -
true