เราต้องเขียนฟังก์ชัน JavaScript ที่รับอาร์เรย์ของจำนวนเต็มที่จัดเรียงและค่าเฉลี่ยเป้าหมายเป็นอาร์กิวเมนต์แรกและตัวที่สอง
ฟังก์ชันควรกำหนดว่ามีคู่ของค่าในอาร์เรย์ที่ค่าเฉลี่ยของทั้งคู่เท่ากับค่าเฉลี่ยเป้าหมายหรือไม่
มีวิธีแก้ปัญหาด้วย O(1) ความซับซ้อนของพื้นที่เพิ่มเติมและความซับซ้อนของเวลา O(n) เนื่องจากอาร์เรย์ถูกจัดเรียง จึงมีดัชนีสองดัชนีที่เหมาะสม:ตัวหนึ่งเริ่มจากจุดสิ้นสุด (เช่น y) อีกตัวหนึ่งจากจุดสิ้นสุดไปยังจุดเริ่มต้นของอาร์เรย์ (เช่น x)
ตัวอย่าง
รหัสสำหรับสิ่งนี้จะเป็น −
const arr = [1, 2, 4, 6, 7, 9, 11]; const averagePair = (arr = [], target = 1) => { let x = arr.length − 1; for (let y = 0; y < x; y++) { while (y < x && arr[x] + arr[y] > 2*target) { x−−; }; if (x !== y && arr[x] + arr[y] === 2 * target) { return true; }; }; return false; }; console.log(averagePair(arr, 6.5));
ผลลัพธ์
และผลลัพธ์ในคอนโซลจะเป็น −
true