字符串-将str1编辑成str2所需最小代价(hard)

一、题目描述

二、解题思路

该题目使用动态规划的思想来解决问题

刚开始我还在想,删除+添加的操作可以等价为替换操作,如果替换操作的Cost大于删除+添加组合操作的Cost之和就需要把 rc=dc+ic。

但是在动态规划中,如果对三种不同的操作方式进行比较然后取较小值,不用进行上面的替换操作就可以达到效果,假设i表示指向str2的指针,j表示指向str1的指针,将str1->str2的过程中

        无非就是一个从对角线 [i-1][j-1] ->(替换) [i][j]           cost=rc

        另一个从 [i-1][j-1] ->(删除) [i-1][j] ->(添加) [i][j]         cost=dc+ic

所以这里的状态转移方程就是:

        deleteCost      =   dp[i][j-1]+dc;

        addCost          =   dp[i-1][j]+ic;

        replaceCost    =   dp[i-1][j-1]+rc;

        dp[i][j]             =   Min(deleteCost,addCost,replaceCost)

初始化dp数组

        dp[0][j] = j*dc        :代表str2为空串,str1只能删除,则花费为 j × dc

        dp[i][0] = i*ic         :代表str1为空串,str1只能添加,则花费为 i × ic        

        

三、代码实现

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** min edit cost* @param str1 string字符串 the string* @param str2 string字符串 the string* @param ic int整型 insert cost* @param dc int整型 delete cost* @param rc int整型 replace cost* @return int整型*/public int minEditCost (String str1, String str2, int ic, int dc, int rc) {//使用动态规划找两个字符串的最小代价int[][] maxCostArr=new int[str2.length()+1][str1.length()+1];//dp数组进行初始化//初始化第一行,当str2为空字符串时for(int i=0;i<=str1.length();i++){maxCostArr[0][i]=i*dc;}//初始化第一列,当str1为空字符串时for(int i=0;i<=str2.length();i++){maxCostArr[i][0]=i*ic;}//双层循环对dp数组进行修改for(int p2=1;p2<=str2.length();p2++){for(int p1=1;p1<=str1.length();p1++){if(str2.charAt(p2-1)==str1.charAt(p1-1)){//Cost不需要增加maxCostArr[p2][p1]=maxCostArr[p2-1][p1-1];}else{//计算三种情况下的代价值,去最小值int deleteCost=maxCostArr[p2][p1-1]+dc;int addCost=maxCostArr[p2-1][p1]+ic;int replaceCost=maxCostArr[p2-1][p1-1]+rc;maxCostArr[p2][p1]=Math.min(deleteCost,Math.min(addCost,replaceCost));}}}return maxCostArr[str2.length()][str1.length()];}
}

四、刷题链接

编辑距离(二)_牛客题霸_牛客网

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/21092.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Centos7】解决 CentOS 7 中出现 “xx: command not found“ 错误的全面指南

【Centos7】初探xx:command not found解决方案 大家好 我是寸铁&#x1f44a; 【Centos7】解决 CentOS 7 中出现 “xx: command not found” 错误的全面指南✨ 喜欢的小伙伴可以点点关注 &#x1f49d; 前言 经常有小伙伴问我&#xff0c;xx:command not found怎么办&#xff1…

Spring原理-IOC和AOP

概述 在此记录spring的学习内容。spring官网&#xff1a;https://spring.io/ 概念故事 从前&#xff0c;在Java的大森林中&#xff0c;有一片神奇的土地&#xff0c;名叫"Spring"。这片土地上生长着各种美丽而强大的植物&#xff0c;它们分别象征着Spring框架中的…

1.1 寻找灵感:怎样像艺术家一样去看待这个世界

“你是从哪里获取到这些创作灵感的&#xff1f;” 当每一个艺术家被问到这个问题时&#xff0c;只有诚实的艺术家会回答&#xff1a; “这是我偷窃的” 怎样像艺术家一样去看待这个世界呢&#xff1f; 你首先需要弄明白什么是值得你偷窃的&#xff0c;然后你才能继续接下来…

如何在一台电脑上安装多个版本的JDK并且切换使用?

如何在一台电脑上安装多个版本的JDK并且切换使用&#xff1f; 文章目录 如何在一台电脑上安装多个版本的JDK并且切换使用&#xff1f;1.目录管理2.下载JDK3.配置环境变量4. 验证 1.目录管理 我们需要首先对不同版本的JDK进行版本管理&#xff0c;如下所示&#xff0c;我在C盘路…

# linux 系统下 切换 root 用户时出现 authentication failure 的解决办法

linux 系统下 切换 root 用户时出现 authentication failure 的解决办法 1、问题分析&#xff1a; 切换 root 用户时出现 authentication failure&#xff0c;意思即 “身份验证失败”&#xff0c;这是由于新安装的系统&#xff0c;可能没有给 root 用户设置密码。 2、解决方…

算法(二)二分查找

文章目录 二分查找简介实现方式循环方式递归方式 经典例子 二分查找简介 二分查找&#xff08;binary search&#xff09;算法&#xff0c;也叫折半算法。二分查找是针对有序的数据集合的查找办法&#xff0c;如果是无序的数据结合就使用遍历。二分查找之所以快速&#xff0c;…

OWASP top10--SQL注入(四、sqlmap安装及使用)

目录 sqlmap工具安装&#xff1a; 工具说明&#xff1a; 主要功能特性包括&#xff1a; 基本使用示例&#xff1a; 先下载python2.7.9版本 sqlmap运行 sqlmap工具使用 -u -r –-levelLEVEL扫描深度级别 --riskRISK 执行测试的风险 -threads 线程数 -batch-smart智能…

JS异步编程

目录 概念定时器Promise对象概念 单线程模型指的是,JavaScript 只在一个线程上运行。也就是说,JavaScript 同时只能执行一个任务,其他任务都必须在后面排队等待。JavaScript 只在一个线程上运行,不代表 JavaScript 引擎只有一个线程。事实上,JavaScript 引擎有多个线程,…

鸿蒙开发加强2

快速创建一个符合长度的数组 空数组 Array.from({length: 200}) // 200的长度的空数组 场景&#xff1a;只确定长度&#xff0c;不确定内容的情况 State 状态装饰器 》增强功能 数据变化了 可以引起页面的重新渲染 没有State修饰的变量&#xff0c;不会引起UI的刷新渲染 加…

php获取今天凌晨零点的时间

不废话直接上代码 //使用strtotime $midnightToday strtotime("today midnight"); //输出&#xff1a;1716998400 //如果是明天 $midnightToday 86400 //后天 $midnightToday 86400*2//ORM中比对使用 $row ModelVisit::where(uid,$this->uid)->where(visi…

C++面试十二连问(语言基础篇)

前言&#xff1a; C开发讲究的是细分领域&#xff0c;越往后越没有人在意你是不是了解语言特性&#xff0c;但是对相关行业经验的要求就越高。作为初入行业的新人&#xff0c;在经验这块是比较欠缺的&#xff0c;相比之下&#xff0c;C八股还是比较容易上手的&#xff0c;属于努…

学习整理 docker

nexus 搭建nexus将其他pom、jar导入到nexus中

java 比Scanner 更高效的输入输出 BufferedWriter和`OutputStreamWriter

BufferedWriter bw new BufferedWriter(new OutputStreamWriter(System.out)); 当我们在 Java 中需要进行字符输出时&#xff0c;可以使用 BufferedWriter 和 OutputStreamWriter 的组合来实现。下面提供更多相关信息&#xff1a; BufferedWriter&#xff1a; BufferedWriter…

硬件接口介绍(一)常用接口及其测试

目录 一、引言 二、常用接口 ------>2.1、DIMM ------>2.2、DCIN ------>2.3、SDIO 三、以太网 ------>3.1、PHY ------>3.2、MAC ------>3.3、LAN 四、MIPI ------>4.1、MIPI CSI ------>4.2、MIPI DSI 五、HDMI 六、音频 ------>6…

fintuning chatglm3

chatglm3介绍 ChatGLM3-6B 是 ChatGLM 系列最新一代的开源模型&#xff0c;在保留了前两代模型对话流畅、部署门槛低等众多优秀特性的基础上&#xff0c;ChatGLM3-6B 引入了如下特性&#xff1a; 更强大的基础模型&#xff1a; ChatGLM3-6B 的基础模型 ChatGLM3-6B-Base 采用…

ic基础|时钟篇06:crg到底是什么?一文带你了解crg中的时钟系统!

大家好&#xff0c;我是数字小熊饼干&#xff0c;一个练习时长两年半的ic打工人。我在两年前通过自学跨行社招加入了IC行业。现在我打算将这两年的工作经验和当初面试时最常问的一些问题进行总结&#xff0c;并通过汇总成文章的形式进行输出&#xff0c;相信无论你是在职的还是…

Material Design 风格的 UI 框架 Vuetify 使用初体验

不知道国外为什么这么多使用 vuetify UI 框架的&#xff0c;简单使用下来发现很多坑。持续更新 1、input 和 button 设置相同的 density&#xff0c;但是大小却不一样&#xff1b; 2、表格功能过于简单&#xff0c;没有列拖拽&#xff0c;只有左侧固定列没有右侧固定列&#…

基于Swing和socket实现双向通讯案例

server代码&#xff1a; import javax.swing.*; import java.awt.*; import java.io.*; import java.net.ServerSocket; import java.net.Socket;public class Server extends JFrame {private JTextArea messageArea;private JTextField textField;private PrintWriter write…

像艺术家一样工作:前言

名人名言 “艺术是盗窃” —— 巴勃罗毕加索 “不成熟的诗人模仿&#xff0c;成熟的诗人偷窃&#xff1b;对于偷窃得到的艺术&#xff0c;坏的诗人丑化它&#xff0c;好的诗人加入自己的理解&#xff0c;使它变得更好&#xff0c;至少会让它有点不同。最优秀的诗人&#xff0…

After Effects 2022(AE2022)支持win版和mac版下载

​After Effects 2022 是由Adobe公司推出的一款专业视频后期制作软件&#xff0c;它主要用于视频合成、视频特效制作、视频剪辑、动画制作等领域。After Effects 2022 内置了丰富的特效和过渡效果&#xff0c;用户可以通过它进行高级的视频合成和动画制作。 该软件具有直观的用…