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

LeetCode72编辑距离

题目描述

  

解析

  一般这种给出两个字符串的动态规划问题都是维护一个二维数组,尺寸和这两个字符串的长度相等,用二维做完了后可以尝试优化空间。这一题其实挺类似1143这题的,只不过相比1143的一种方式,变成了三种方式,就要找三个值,在其中取最小的那一个。

public static int minDistance(String word1, String word2) {char[] w1 = word1.toCharArray();char[] w2 = word2.toCharArray();int len1 = word1.length();int len2 = word2.length();int[][] dp = new int[len1 + 1][len2 + 1];// 初始化第一行和第一列for (int i = 0; i <= len1; i++) {dp[i][0] = i;}for (int j = 0; j <= len2; j++) {dp[0][j] = j;}// 填充dp数组for (int i = 1; i <= len1; i++) {for (int j = 1; j <= len2; j++) {int cost = (w1[i - 1] == w2[j - 1]) ? 0 : 1;dp[i][j] = Math.min(dp[i - 1][j] + 1, // 删除Math.min(dp[i][j - 1] + 1, // 插入dp[i - 1][j - 1] + cost)); // 替换}}return dp[len1][len2];}

在这里插入图片描述

http://www.lryc.cn/news/367544.html

相关文章:

  • 竞拍商城系统源码后端PHP+前端UNIAPP
  • 千益畅行,共享旅游卡,灵活同行,畅游无忧的全方位解析
  • Web IDE 在线编辑器综合实践(Web IDE 技术探索 三)
  • Less is more VS 精一 [生活感悟]
  • 函数的概念及图像
  • Linux中Apache网站基于Http服务的访问限制(基于地址/用户)
  • 滚动条详解:跨平台iOS、Android、小程序滚动条隐藏及自定义样式综合指南
  • 06 Linux 设备驱动模型
  • 检测五个数是否一样的算法
  • java 原生http服务器 测试JS前端ajax访问实现跨域传post数据
  • 【机器学习】消息传递神经网络(MPNN)在分子预测领域的医学应用
  • Python Flask实现蓝图Blueprint配置和模块渲染
  • Vue10-事件修饰符
  • oracle中如何查询特定日期?
  • Python使用rosbag使用getattr只能获取一层的数据,不能直接获取多层数据例如 a.b.c.d。使用for range写一个递归用来获取多层数据
  • LNWT--篇章三小测
  • 【NoSQL】Redis练习
  • Git 和 Github 的使用
  • 学习分享-断路器Hystrix与Sentinel的区别
  • 社区物资交易互助平台的设计
  • 19-Nacos-服务实例的权重设置
  • R语言数据探索和分析23-公共物品问卷分析
  • Webix前端界面框架:深度解析与应用实践
  • Qt基于SQLite数据库的增删查改demo
  • 新书推荐:2.2.4 第11练:消息循环
  • MASA:匹配一切、分割一切、跟踪一切
  • Websocket前端传参:深度解析与实战应用
  • 造假高手——faker
  • 前端工程化工具系列(十二)—— PostCSS(v8.4.38):CSS 转换工具
  • Scanpy(3)单细胞数据分析常规流程