当前位置: 首页 > news >正文

西安高端网站设计公司南昌哪家做网站好

西安高端网站设计公司,南昌哪家做网站好,网站代备案需要多少钱,合肥能做网站的公司代码随想录算法训练营第56天|583. 两个字符串的删除操作,72. 编辑距离 583. 两个字符串的删除操作72. 编辑距离 583. 两个字符串的删除操作 题目链接:583. 两个字符串的删除操作,难度:中等 【实现代码】 class Solution { publi…

代码随想录算法训练营第56天|583. 两个字符串的删除操作,72. 编辑距离

  • 583. 两个字符串的删除操作
  • 72. 编辑距离

583. 两个字符串的删除操作

题目链接:583. 两个字符串的删除操作,难度:中等
【实现代码】

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

【解题思路】

动规五部曲

  1. 确定dp数组(dp table)以及下标的含义:dp[i][j]:以i-1为结尾的字符串word1,和以j-1位结尾的字符串word2,想要达到相等,所需要删除元素的最少次数。
  2. 确定递推公式:当word1[i - 1] 与 word2[j - 1]相同的时候,dp[i][j] = dp[i - 1][j - 1];
    当word1[i - 1] 与 word2[j - 1]不相同的时候,有三种情况:
    a) 情况一:删word1[i - 1],最少操作次数为dp[i - 1][j] + 1;
    b) 情况二:删word2[j - 1],最少操作次数为dp[i][j - 1] + 1;
    c) 情况三:同时删word1[i - 1]和word2[j - 1],操作的最少次数为dp[i - 1][j - 1] + 2
    最后当然是取最小值,所以当word1[i - 1] 与 word2[j - 1]不相同的时候,递推公式:dp[i][j] = min({dp[i - 1][j - 1] + 2, dp[i - 1][j] + 1, dp[i][j - 1] + 1});因为 dp[i][j - 1] + 1 = dp[i - 1][j - 1] + 2,所以递推公式可简化为:dp[i][j] = min(dp[i - 1][j] + 1, dp[i][j - 1] + 1);
  3. dp数组如何初始化:dp[i][0]:word2为空字符串,以i-1为结尾的字符串word1要删除多少个元素,才能和word2相同呢,很明显dp[i][0] = i。dp[0][j]的话同理
  4. 确定遍历顺序:遍历的时候一定是从上到下,从左到右
  5. 举例推导dp数组

72. 编辑距离

题目链接:72. 编辑距离,难度:困难
【实现代码】

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

【解题思路】

动规五部曲

  1. 确定dp数组(dp table)以及下标的含义:dp[i][j]:以i-1为结尾的字符串word1,和以j-1位结尾的字符串word2,想要达到相等,所需要删除元素的最少次数。
  2. 确定递推公式:当word1[i - 1] 与 word2[j - 1]相同的时候,dp[i][j] = dp[i - 1][j - 1];
    当word1[i - 1] 与 word2[j - 1]不相同的时候,有三种情况:
    a)word1删除一个元素,那么就是以下标i - 2为结尾的word1 与 j-1为结尾的word2的最近编辑距离 再加上一个操作,即 dp[i][j] = dp[i - 1][j] + 1
    b) 操作二:word2删除一个元素,那么就是以下标i - 1为结尾的word1 与 j-2为结尾的word2的最近编辑距离 再加上一个操作。即 dp[i][j] = dp[i][j - 1] + 1;
    word2添加一个元素,相当于word1删除一个元素,例如 word1 = “ad” ,word2 = “a”,word1删除元素’d’ 和 word2添加一个元素’d’,变成word1=“a”, word2=“ad”, 最终的操作数是一样
    c) 只需要一次替换的操作,就可以让 word1[i - 1] 和 word2[j - 1] 相同。所以 dp[i][j] = dp[i - 1][j - 1] + 1;
  3. dp数组如何初始化:dp[i][0]:word2为空字符串,以i-1为结尾的字符串word1要删除多少个元素,才能和word2相同呢,很明显dp[i][0] = i。dp[0][j]的话同理
  4. 确定遍历顺序:遍历的时候一定是从上到下,从左到右
  5. 举例推导dp数组
http://www.yayakq.cn/news/851467/

相关文章:

  • 微网站一键导航三亚本地网
  • 超级外链自动发布工具国外seo比较好的博客网站
  • 青岛公司网站建设开发中学生免费作文网站
  • 免费建网站家谱系统自己怎么做鲜花网站
  • wordpress做网站教程建设自己的网站
  • 公司注册资金最新规定成都seo招聘信息
  • 江苏建设厅网站查询apache 创建网站
  • wordpress网站导入数据库wordpress 站内搜索代码
  • 懂网络维护和网站建设的专业网站备案流程实名认证
  • 朝阳专业网站建设公司舟山大昌建设集团网站
  • 微信公众平台对接网站最新新闻事件今天300字
  • 宿迁做网站的整站seo优化哪家好
  • 国内做的比较好的二手网站1空间做2个网站
  • wordpress 中文网站网站怎么响应式布局
  • 淮安做网站就找卓越凯欣长春新闻最新消息
  • 西安优秀高端网站建设服务商南宁庆云网站建设
  • 化工行业网站建设禅城建网站
  • 做网站的公司上海免费创意logo一键生成器
  • 上海建网站制微信公用号 wordpress
  • 网站建设属于什么职能国外的做的比较优秀的网站有哪些
  • 网站建设与管理专业就业新乡 网站建设
  • 手机网站制作的价格邯郸技术服务类
  • 网站魔板大全网络营销工具的定义
  • 做网站外包群网页设计公司兴田德润i简介
  • 网站建设公司小程序开发宠物网站模版
  • 解决wordpress更改新域名后网站不能访问的问题做h5哪些网站好 知乎
  • 中英文双语网站怎么做wordpress 建站后端
  • 网站模块顺序调整巩义服务专业网站建设
  • 网站建设主题自媒体怎么做
  • 深圳大型论坛网站建设指数分布