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

2024-06-03 02:52

本文主要是介绍字符串-将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()];}
}

四、刷题链接

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

这篇关于字符串-将str1编辑成str2所需最小代价(hard)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1025831

相关文章

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

golang float和科学计数法转字符串的实现方式

《golangfloat和科学计数法转字符串的实现方式》:本文主要介绍golangfloat和科学计数法转字符串的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望... 目录golang float和科学计数法转字符串需要对float转字符串做处理总结golang float

Python如何判断字符串中是否包含特殊字符并替换

《Python如何判断字符串中是否包含特殊字符并替换》这篇文章主要为大家详细介绍了如何使用Python实现判断字符串中是否包含特殊字符并使用空字符串替换掉,文中的示例代码讲解详细,感兴趣的小伙伴可以了... 目录python判断字符串中是否包含特殊字符方法一:使用正则表达式方法二:手动检查特定字符Pytho

MySQL 字符串截取函数及用法详解

《MySQL字符串截取函数及用法详解》在MySQL中,字符串截取是常见的操作,主要用于从字符串中提取特定部分,MySQL提供了多种函数来实现这一功能,包括LEFT()、RIGHT()、SUBST... 目录mysql 字符串截取函数详解RIGHT(str, length):从右侧截取指定长度的字符SUBST

Python将字符串转换为小写字母的几种常用方法

《Python将字符串转换为小写字母的几种常用方法》:本文主要介绍Python中将字符串大写字母转小写的四种方法:lower()方法简洁高效,手动ASCII转换灵活可控,str.translate... 目录一、使用内置方法 lower()(最简单)二、手动遍历 + ASCII 码转换三、使用 str.tr

Java如何用乘号来重复字符串的功能

《Java如何用乘号来重复字符串的功能》:本文主要介绍Java使用乘号来重复字符串的功能,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java乘号来重复字符串的功能1、利用循环2、使用StringBuilder3、采用 Java 11 引入的String.rep

Python+Tkinter实现Windows Hosts文件编辑管理工具

《Python+Tkinter实现WindowsHosts文件编辑管理工具》在日常开发和网络调试或科学上网场景中,Hosts文件修改是每个开发者都绕不开的必修课,本文将完整解析一个基于Python... 目录一、前言:为什么我们需要专业的Hosts管理工具二、工具核心功能全景图2.1 基础功能模块2.2 进