算法--编辑距离问题

在这里插入图片描述
该动态规划方程借鉴博客
https://www.cnblogs.com/littlepanpc/p/7895810.html

代码如下:

#include<stdio.h> #include<string.h> //将A转换为B所用的最少字符操作数称为A到B的编辑距离,记为Shortest_Distance[A][B] char a[100]; char b[100]; int Shortest_Distance[100][100]; int Edit_distance(int m,int n){ int p; int q; int r; //第一种情况:两个字符串都是空字符串 if(m==-1&&n==-1){ return 0; } //第二种情况:有一个字符串为空 if(m==-1&&n!=-1){ return n+1; }else if(m!=-1&&n==-1){ return m+1; } //第三种情况:两个字符串都不为空,找最短距离 if(m!=-1&&n!=-1){ int flag=1; if(a[m]==b[n]){ flag=0; } p=Edit_distance(m-1,n)+1; q=Edit_distance(m,n-1)+1; r=Edit_distance(m-1,n-1)+flag; if(p<q&&p<r){ return p; //这是对A字符串的末尾进行删除,从而使得AB字符串末尾的字符相等 }else if(p>q&&q<r){ return q; //这是在A字符串的末尾增加字符,从而使得AB字符串末尾的字符相等 }else if(p>r&&q>r){ return r; //这是对A字符串的末尾进行修改,从而使得AB字符串末尾的字符相等 } } } int main(){ gets(a); gets(b); int len_a=strlen(a); int len_b=strlen(b); int sss=Edit_distance(len_a-1,len_b-1); printf("%d",sss); return 0; }

__EOF__

本文作者坤舆小菜鸡
本文链接https://www.cnblogs.com/HBU-xuhaiyang/p/17223181.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   坤舆小菜鸡  阅读(15)  评论(0编辑  收藏  举报  
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示