题解 | #计算字符串的距离#

计算字符串的距离

http://www.nowcoder.com/practice/3959837097c7413a961a135d7104c314

//参考https://www.jianshu.com/p/90af98493661
while(str = readline()) {
    print(minDistance(str,readline())) // 2
}

function minDistance(s1, s2) {
    const len1 = s1.length
    const len2 = s2.length

    let matrix = []

    for (let i = 0; i <= len1; i++) {
        // 构造二维数组
        matrix[i] = new Array()
        for (let j = 0; j <= len2; j++) {
            // 初始化
            if (i == 0) {
                matrix[i][j] = j
            } else if (j == 0) {
                matrix[i][j] = i
            } else {
                // 进行最小值分析
                let cost = 0
                if (s1[i - 1] != s2[j - 1]) { // 相同为0,不同置1
                    cost = 1
                }
                const temp = matrix[i - 1][j - 1] + cost

                matrix[i][j] = Math.min(matrix[i - 1][j] + 1, matrix[i][j - 1] + 1, temp)
            }
        }
    }
    return matrix[len1][len2] //返回右下角的值
}

全部评论
看着有点懵逼
点赞 回复 分享
发布于 2022-10-13 17:08 广东
大佬,可以解释一下,为啥matrix[i - 1][j] + 1代表删除,matrix[i][j - 1] + 1代表新增,temp代表替换???
点赞 回复 分享
发布于 2023-03-06 11:21 广东

相关推荐

Natrium_:这时间我以为飞机票
点赞 评论 收藏
分享
dongsheng66:如果想进大厂的话,在校经历没必要占这么大篇幅,可以把专业技能单独放一个专栏写,可以加个项目经历
点赞 评论 收藏
分享
2 收藏 评论
分享
牛客网
牛客企业服务