Cari subrentetan menggunakan fungsi JavaScript
P粉098979048
P粉098979048 2023-09-13 11:04:31
0
1
497

Saya ingin menulis kod dalam bahasa JavaScript yang boleh mencari bilangan ulangan huruf dalam perkataan, seperti kod ini, tetapi dengan cara yang lebih pendek o(n).

function naiveSearch(long, short){
    var count = 0;
    for(var i = 0; i < long.length; i++){
        for(var j = 0; j < short.length; j++){
           if(short[j] !== long[i+j]) break;
           if(j === short.length - 1) count++;
        }
    }
    return count;
}
naiveSearch("lorielol loled", "lol")

P粉098979048
P粉098979048

membalas semua(1)
P粉958986070

Gunakan kaedah .substring().slice() dan bukannya gelung bersarang.

function naiveSearch(long, short) {
  var count = 0;
  for (var i = 0, limit = long.length - short.length; i < limit; i++) {
    if (long.substring(i, i + short.length) == short) {
      count++;
    }
  }
  return count;
}

console.log(naiveSearch("lorielol loled", "lol"));
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan