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

编辑距离(一)

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
    }
    
}
全部评论

相关推荐

07-14 12:29
门头沟学院 Java
后端岗,实习三周感觉有点想跑路了,担心秋招被拉黑,有没有佬是字节HR知道情况的
从零开始的转码生活:你实习三周都想跑路,将来拿到offer真的愿意在这干十几二十年吗
投递字节跳动等公司8个岗位
点赞 评论 收藏
分享
07-11 15:12
门头沟学院 Java
别人在上班,我就在工位上看看视频啥的,这正常吗?
程序员小白条:实习就是摸鱼,只是公司指标,把你进来了,可能那时候客户很多,但等你进来的时候,已经是淡季了,根本没多少需求,或者说根本不适合实习生去完成,因此你就每天干坐着就行,可能1,2个月都没需求
实习生的蛐蛐区
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务