直播平台搭建,编辑距离控制和调节

直播平台搭建,编辑距离控制和调节

 

/**
 * @param {string} word1
 * @param {string} word2
 * @return {number}
 */
var minDistance = function (word1, word2) {
  let dp = Array.from(Array(word1.length + 1), () =>
    Array(word2.length + 1).fill(0)
  );
  /* base case 是i走完word1或j走完word2,可以直接返回另一个字符串剩下的长度 */
  // j走完word2 如果i还没走完word1,那么只能用删除操作把word1缩短为word2,也就是直接返回另一个字符串剩下的长度
  for (let i = 1; i <= word1.length; i++) {
    dp[i][0] = i;
  }
  // 同理  如果i走完word1时j还没走完了word2,那就只能用插入操作把word2剩下的字符全部插入word1
  for (let j = 1; j <= word2.length; j++) {
    dp[0][j] = j;
  }
  for (let i = 1; i <= word1.length; i++) {
    for (let j = 1; j <= word2.length; j++) {
      if (word1[i - 1] === word2[j - 1]) {
        // 啥也不做
        dp[i][j] = dp[i - 1][j - 1];
      } else {
        // 三选一  哪个操作最后得到的编辑距离最小,就选谁
        dp[i][j] = Math.min(
          // 删除
          // 直接把word1[i]这个字符删掉,前移i继续跟j对比   操作数+1
          dp[i - 1][j] + 1,
          // 插入
          // 直接在word1[i]插入一个和word2[j]一样的字符,那么word2[j]就被匹配了,前移j继续跟i对比
          dp[i][j - 1] + 1,
          // 替换
          // 直接把word1[i]替换成word2[j] 这样它俩就匹配了,同时前移i,j继续对比
          dp[i - 1][j - 1] + 1
        );
      }
    }
  }
  return dp[word1.length][word2.length];
};

以上就是 直播平台搭建,编辑距离控制和调节,更多内容欢迎关注之后的文章

 

posted @ 2023-06-05 14:12  云豹科技-苏凌霄  阅读(63)  评论(0编辑  收藏  举报