leetcode72难动态规划

题意;经由最小的操作数把串S变为串T:

理论bfs是可行的的。

转化为对其字符串问题,

对于空字符:

s的字符为添加,T的字符为减少

不同则为修改。

 用dpij表示最少得分,加一个数组sameij表示ij是否相等。

三种情况:1上面已讲

2.dpi-1j+1 也就是s的第i个字符和空对其,即删除

3.dpij-1+1添加


初值: dp0j=j dpi0=i


注意:每个i正向循环j   dpi-1j-1已经是新值了。


class Solution {
public:
    int minDistance(string word1, string word2) {
        int m = word1.length(), n=word2.length();
        vector<vector<int> > dp(m+1,vector<int>(n+1));
        for(int i=0;i<=m;i++){
            for(int j=0;j<=n;j++){
                if(i==0){
                    dp[i][j]=j;
                }
                else if(j==0){
                    dp[i][j]=i;
                }
                else {
                    dp[i][j] = min(dp[i-1][j-1]+((word1[i-1]==word2[j-1])?0:1),
                                   min(dp[i][j-1]+1,dp[i-1][j]+1)
                                   );
                }
            }
        }
        return dp[m][n];
    }
};
然后减了一维的空间:

class Solution {
public:
    int minDistance(string word1, string word2) {
        int m = word1.length(), n=word2.length();
        vector<int> dp(n+1);
        for(int i=0;i<=m;i++){
            int last;
            for(int j=0;j<=n;j++){
                if(i==0){
                    dp[j]=j;
                }
                else if(j==0){
                    last=dp[j];
                    dp[j]=i;
                    
                }
                else {
                    int temp = dp[j];
                    dp[j] = min(last+((word1[i-1]==word2[j-1])?0:1),
                                   min(dp[j-1]+1,dp[j]+1)
                                   );
                    last=temp;
                }
            }
        }
        return dp[n];
    }
};



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值