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

ค้นหา Max Slice Of Array | JavaScript


สมมติว่า เราต้องเขียนฟังก์ชันที่รับอาร์เรย์เป็นอินพุตและส่งกลับส่วนสูงสุดของอาร์เรย์ที่มีตัวเลขต่างกันไม่เกินสองตัว หากเราตรวจสอบปัญหานี้อย่างใกล้ชิด จะต้องตรวจสอบอาร์เรย์ย่อยที่เสถียรและวนซ้ำบนอาร์เรย์ต้นฉบับ

ดังนั้นอัลกอริธึมหน้าต่างบานเลื่อนจึงเหมาะสมมากสำหรับสิ่งนี้ รหัสสำหรับแก้ปัญหานี้โดยใช้อัลกอริธึมหน้าต่างบานเลื่อนจะเป็น -

ตัวอย่าง

const arr = [1, 1, 1, 2, 2, 2, 1, 1, 2, 2, 6, 2, 1, 8, 1, 1 ,1 ,1, 8, 1,
1, 8, 8];
const map = {
   length: 0
};
let required = [];
for(start = 0, end = 0; end <= arr.length; ){
   if(map.length > 2){
      if(map[arr[start]] === 1){
         delete map[arr[start]];
         map.length --;
      }else{
         map[arr[start]]--;
      };
      start++;
      }else{
      if(end - start > required.length){
         required = arr.slice(start, end);
      };
      if(map[arr[end]]){
         map[arr[end]]++;
      }else{
         map[arr[end]] = 1;
         map.length++;
      }
      end++;
   }
}
console.log(required);

เรารักษาแผนที่สำหรับจัดเก็บการนับจำนวนอักขระที่แตกต่างกัน ณ จุดใดก็ได้ในอาร์เรย์ และเปรียบเทียบความยาวของอาร์เรย์ย่อยที่ยาวที่สุดในการวนซ้ำแต่ละครั้ง เมื่อจำนวนอักขระที่แตกต่างกันเกิน 2 เราจะเลื่อนอาร์เรย์ไปทางขวาเพื่อค้นหาอาร์เรย์ที่เสถียรถัดไป

ผลลัพธ์

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

[
   1, 8, 1, 1, 1,
   1, 8, 1, 1, 8,
   8
]