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

计算字符串的编辑距离

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

题解与证明:levenshtein算法是正确的

#include<stdio.h>
#include<string.h>

char stri[1001],strj[1001];
int matrix[1001][1001];

int lev(int i,int j){
    if(stri[i-1]==strj[j-1])
        return matrix[i-1][j-1];
    int min=matrix[i-1][j-1];
    min=min<=matrix[i-1][j]?min:matrix[i-1][j];
    min=min<=matrix[i][j-1]?min:matrix[i][j-1];
    return min+1;
}

int main(){

    while(scanf("%s",stri)!=EOF){
        scanf("%s",strj);
        int leni=strlen(stri),lenj=strlen(strj);
        int i=0,j=0;
        while(i<=leni){
            matrix[i][0]=i;
            i++;
        }
        while(j<=lenj){
            matrix[0][j]=j;
            j++;
        }
        for(j=1;j<=lenj;j++)
            for(i=1;i<=leni;i++)
                matrix[i][j]=lev(i,j);
        printf("%d\n",matrix[leni][lenj]);
    }
}

alt alt

全部评论

相关推荐

06-26 10:08
门头沟学院 C++
北京Golang实习,一个月4700,吃住都不报,公司位置在海淀。请问友友怎么看呢?如果要租房的话有什么建议吗
码农索隆:租房肯定是合租了,剩下的钱,差不多够正常吃饭了,看看能不能学到东西吧
点赞 评论 收藏
分享
xdm怎么说&nbsp;要被拷打了&nbsp;担心是KPI
丹田:面就完了,就当日薪四位数的大佬免费给给你面试。
点赞 评论 收藏
分享
06-27 15:15
长安大学 Java
哈哈哈,你是老六:这种就是培训机构骗钱的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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