leetcode 面试题 01.05. 一次编辑 动态规划

面试题 01.05. 一次编辑

其实就是编辑距离 leetcode 72 编辑距离 动态规划

class Solution {
public:
    int min(int a, int b, int c) {
        int temp = a > b ? b : a;
        int result = c > temp ? temp : c;
        return result;
    }
    bool oneEditAway(string first, string second) {
        int m=first.length();
        int n=second.length();
        int dp[n+1];
        for(int i=0;i<=n;++i){
            dp[i]=i;  //刚开始dp[i]是从啥都没有变成word2前i个字符所需的步数
        }
        for(int j=1;j<=m;++j){    //分别遍历从有i个字符的word1变到word2的前i个字符所需步数dp[i]
            int tmp=dp[0];
            dp[0]=j;
            for(int i=1;i<=n;++i){
                int pre=tmp;
                tmp=dp[i];
                if(first[j-1]==second[i-1]){
                    dp[i]=pre;
                }else{
                    dp[i]=min(dp[i-1],pre,dp[i])+1;
                }
            }
        }
        return dp[n]<2;
    }
};

当然还有双指针可以做,但是,先一招鲜,学明白动态规划再说

posted on 2021-06-06 18:32  雾恋过往  阅读(27)  评论(0编辑  收藏  举报

Live2D