สมมติว่า เราต้องเขียนฟังก์ชัน String.prototype ที่มีสามอาร์กิวเมนต์
- อาร์กิวเมนต์แรกคือสตริงที่ควรค้นหาสำหรับสตริงย่อย
- อาร์กิวเมนต์ที่สองคือสตริง เหตุการณ์ที่สตริงจะถูกลบออก
- อาร์กิวเมนต์ที่สามคือตัวเลขที่บอกว่า n, การเกิดขึ้นครั้งที่ n ของสตริงย่อยที่จะถูกลบออกจากสตริง
ฟังก์ชันควรส่งคืนสตริงใหม่หากการลบ subStr ออกจากสตริงสำเร็จ มิฉะนั้น ควรคืนค่า -1 ในทุกกรณี
ตัวอย่าง
ต่อไปนี้เป็นรหัส -
const str = 'jkdsttjkdsre';
const subStr = 'jk';
const num = 2;
removeStr = function(subStr, num){
if(!this.includes(subStr)){
return -1;
}
let start = 0, end = subStr.length;
let occurences = 0;
for(; ;end < this.length){
if(this.substring(start, end) === subStr){
occurences++;
};
if(occurences === num){
return this.substring(0, start) + this.substring(end,this.length);
};
end++;
start++;
}
}
String.prototype.removeStr = removeStr;
console.log(str.removeStr(subStr, num)); ฟังก์ชันนี้จะตรวจสอบก่อน:หากไม่มี subStr เกิดขึ้นแม้แต่ครั้งเดียว เราควรออกจากการทำงานและคืนค่า -1
จากนั้นจะใช้อัลกอริธึมหน้าต่างบานเลื่อนเพื่อบันทึกจำนวนการเกิดขึ้นของ subStr ในสตริง (ขนาดของหน้าต่างเท่ากับความยาวของ subStr)
เริ่มแรก เราเริ่มจากหน้าต่างซ้ายสุด จากนั้นเราค่อยเลื่อนหน้าต่างของเราไปจนสุดหน้าต่างไปถึงจุดสิ้นสุดของสตริงเดิม หากในทางของเรา จำนวนการเกิดเท่ากับการเกิดขึ้นที่ต้องการ เราจะตัดการเกิดขึ้นนั้นออกจากสตริงและส่งคืนสตริงใหม่ที่ได้รับ
หากเราวนซ้ำตลอดทั้งสตริง แสดงว่ามี subStr ในสตริงไม่เพียงพอ และในกรณีนั้นเราควรคืนค่า -1 และออกจากฟังก์ชัน
สุดท้าย เราเพิ่มคุณสมบัติ removeStr ให้กับ String.prototype เพื่อให้เราสามารถเรียกมันว่าเป็นฟังก์ชันสตริงได้
ผลลัพธ์
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ในคอนโซล -
jkdsttdsre