题解 | #编辑距离(一)#

编辑距离(一)

http://www.nowcoder.com/practice/6a1483b5be1547b1acd7940f867be0da

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param str1 string字符串 
 * @param str2 string字符串 
 * @return int整型
*/
func editDistance( str1 string ,  str2 string ) int {
    n := len(str1)
    m := len(str2)
    memo := make([][]int, n)
    for i := 0; i < n; i++{
        memo[i] = make([]int, m)
        for j := 0; j < m; j++ {
            memo[i][j] = -1
        }
    }
    var dp func(int, int) int 
    dp = func (i, j int) int {
        if i == -1 {
            return j + 1
        }
        if j == -1 {
            return i + 1
        }
        if memo[i][j] != -1 {
            return memo[i][j]
        }
        if str1[i] == str2[j] {
            memo[i][j] = dp(i-1, j-1)
        }else {
            memo[i][j] = Min(dp(i, j-1)+1, dp(i-1, j)+1, dp(i-1, j-1)+1)
        }
        return memo[i][j]
    }
    return dp(n-1, m-1)
}
func Min(a, b, c int) int {
    if a < b || a < c {
        return a
    }else if b < a || b < c {
        return b
    }else {
        return c
    }
    
}
全部评论

相关推荐

mikufan_bjtu:(警惕老哥新型赛博钓鱼) 项目可以侧重两个擅长项目,内容最好分成点去写,比一大段看着好。本科的荣誉也可以网上加一加,先说这么多8
点赞 评论 收藏
分享
WesterlyDrift:你拍完照又把选项改回去的样子真的很狼狈😤😤
点赞 评论 收藏
分享
vivo 软件开发 20k*15
大呲花i:62.3k属实让我惊呆了
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务