Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Javascript

แก้ปัญหา Sherlock and Array ใน JavaScript


วัตสันให้อาร์เรย์ A ยาว N แก่เชอร์ล็อก จากนั้นเขาขอให้เขาตรวจสอบว่ามีองค์ประกอบในอาร์เรย์หรือไม่ โดยที่ผลรวมขององค์ประกอบทางด้านซ้ายจะเท่ากับผลรวมขององค์ประกอบทางด้านขวา

เราต้องเขียนฟังก์ชันนี้ ควรใช้ในอาร์เรย์ของ Numbers และตัวเลขใดๆ ที่มีอยู่ในอาร์เรย์ ควรคืนค่าดัชนี มิฉะนั้น ควรคืนค่า -1 เรามาเขียนโค้ดของฟังก์ชันนี้กันดีกว่า −

ตัวอย่าง

const arr = [1, 2, 3, 4, 5, 7, 3];
const arr2 = [4, 6, 3, 4, 5, 2, 1];
const isSherlockArray = arr => {
   let sum = arr.reduce((acc, val) => acc+val);
   let leftSum = 0;
   for(let i = 0; i < arr.length; i++){
      sum -= arr[i];
      if(sum === leftSum){
         return i;
      };
      leftSum += arr[i];
   };
   return -1;
};
console.log(isSherlockArray(arr));
console.log(isSherlockArray(arr2));

ผลลัพธ์

ผลลัพธ์ในคอนโซลจะเป็น -

4
-1