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

编辑距离(一)

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

其实容易发现具有最优子结构,但状态以及状态的转换不好想。因为是两个字符串,所以定义dp[i][j]为s1的前i个s2的前j个的最短编辑距离。发现最后一步的不同点在于字符串不同时对字符串的操作,插入,删除或修改,对s1最后插入和删除s2最后是一样的效果,所以最后可以归纳为3中操作:

  1. 在s1最后插入和s2最后一个字符相同的字符
  2. 在s2最后插入和s1最后一个字符相同的字符
  3. 替换s1最后和s2不同的字符

操作1:转化为dp[i][j-1],即判断s1的前i个s2的前j-1个字符的最短编辑距离,无需考虑s2的第j个字符(因为会在s1的末尾插入)

操作2:转化为dp[i-1][j]

操作3:转化为dp[i-1][j-1]

最后得到状态的转化:

若 A 和 B 的最后一个字母相同:
D[i][j]
=1+min(D[i][j−1],D[i−1][j],D[i−1][j−1]−1)
 
若 A 和 B 的最后一个字母不同:
D[i][j]=1+min(D[i][j−1],D[i−1][j],D[i−1][j−1])

代码:

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param str1 string字符串 
     * @param str2 string字符串 
     * @return int整型
     */
    public int editDistance (String str1, String str2) {
        // write code here
        if(str1==null||str2==null||str1.length()==0||str2.length()==0){
            return 0;
        }
        int len1=str1.length();
        int len2=str2.length();
        char[] ss=str2.toCharArray();
        int[][] dp=new int[len1+1][len2+1];
        
        for(int i=1;i<=len1;i++){
            dp[i][0]=i;
            char c=str1.charAt(i-1);
            for(int j=1;j<=len2;j++){
                dp[0][j]=j;
                if(c==ss[j-1]){
                    dp[i][j]=Math.min(Math.min(dp[i-1][j],dp[i][j-1]),dp[i-1][j-1]-1)+1;
                }else{
                    dp[i][j]=Math.min(Math.min(dp[i-1][j],dp[i][j-1]),dp[i-1][j-1])+1;
                }
            }
        }
        return dp[len1][len2];    
        
        
    }
}
全部评论

相关推荐

好久没来牛客了,今天面试了一个实习生,感觉对方形象乱糟糟的,头发像鸡窝,像刚睡醒就来面试了,第一印象直接大打折扣,感觉我没有受到应有的尊重,再加上对方业务能力也一般,我直接挂掉;大家面试的时候还是好好收拾一下自己吧,争取给面试官留下个好印象,面试这东西还是存在眼缘的
MinJerous:更在乎本质,应该看候选人是否和岗位需要的能力匹配。洗脸/不洗头都无所谓吧,说不定人家刚刚通宵准备,就是为了这场面试呢?你挂掉他核心原因还是他能力不行,而不是形象。就算形象好点,能力不行你敢给过吗,不怕后面+1质疑你
点赞 评论 收藏
分享
吐泡泡的咸鱼:我也工作了几年了,也陆陆续续面试过不少人,就简历来说,第一眼学历不太够,你只能靠你的实习或者论文或者项目经历,然后你没有论文,没有含金量高的比赛和奖项,只能看实习和项目,实习来说,你写的实习经历完全不清楚你想找什么工作?行研?数据分析?且写的太少了,再看项目,这些项目先不说上过大学读过研究生的都知道很水,然后对你想找的岗位有什么帮助呢?项目和实习也完全不匹配啊,你好像在努力将你所有的经历都放在简历里想表现你的优秀,但是对于你想找的岗位来说,有什么用呢?最后只能获得岗位不匹配的评价。所以你需要明白你想要找的岗位要求是什么,是做什么的,比如产品经理,然后再看你的经历里有什么匹配的上这个岗位,或者对这个岗位以及这个岗位所在的公司有价值,再写到你的简历上
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务