题解 | #计算字符串的编辑距离#

计算字符串的编辑距离

https://www.nowcoder.com/practice/3959837097c7413a961a135d7104c314

import java.util.*;

import java.io.*;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        char[] a = br.readLine().toCharArray();
        char[] b = br.readLine().toCharArray();
        // dp[i][j] a字符串第i个字符b字符串第j个字符时的最小距离 dp[i][j]= Min(dp[i][j-1]+1,dp[i-1][j]+1,dp[i-1][j-1]+(a[i]==b[j]?0:1))
        int[][] dp = new int[a.length + 1][b.length + 1];
        //初始化,记录当一个字符串为空时,另一个字符串的距离即为其长度
        for (int i = 0; i < a.length + 1; i++) {
            dp[i][0] = i;
        }
        for (int i = 0; i < b.length + 1; i++) {
            dp[0][i] = i;
        }
        //动态规划依次取值,当前值取决于其 左 左上,上 三个的值
        for (int i = 1; i < a.length + 1; i++) {
            for (int j = 1; j < b.length + 1; j++) {
                int left = dp[i][j - 1] + 1;
                int up = dp[i - 1][j] + 1;
                int leftUp = dp[i - 1][j - 1] + (a[i - 1] == b[j - 1] ? 0 : 1);
                dp[i][j] = Math.min(Math.min(left, up), leftUp);
            }
        }
        System.out.print(dp[a.length][b.length]);
    }
}

全部评论

相关推荐

WhiteAlbum...:学院本2中大厂垂直实习➕acm比赛 秋招0面试
点赞 评论 收藏
分享
09-18 20:41
阿里巴巴_后端
要个offer怎么这...:哈哈哈哈哈哈,我也拿了0x10000000个offer,秋招温啦啦啦,好开心
我的秋招日记
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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