LeetCode —— 1312. 让字符串成为回文串的最少插入次数

2023-12-01 04:18

本文主要是介绍LeetCode —— 1312. 让字符串成为回文串的最少插入次数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 题目描述
  • 示例
    • 示例一
    • 示例二
    • 示例三
    • 示例四
    • 示例五
  • 解题思路
  • 代码呈现
  • 参考文献

题目描述

给你一个字符串 s ,每一次操作你都可以在字符串的任意位置插入任意字符。

请你返回让 s 成为回文串的 最少操作次数 。

「回文串」是正读和反读都相同的字符串。

示例

示例一

输入:s = "zzazz"
输出:0
解释:字符串 "zzazz" 已经是回文串了,所以不需要做任何插入操作。

示例二

输入:s = "mbadm"
输出:2
解释:字符串可变为 "mbdadbm" 或者 "mdbabdm"

示例三

输入:s = "leetcode"
输出:5
解释:插入 5 个字符后字符串变为 "leetcodocteel"

示例四

输入:s = "g"
输出:0

示例五

输入:s = "no"
输出:1

解题思路

这道题的解法是动态规划,我们就拿下面这个字符串举例:
在这里插入图片描述

首先对于每个单个的字符来说,其肯定是回文串。那么假如我们构建的dp[i][j]来表示i~j范围内构成回文串所需要的步骤数。那么这个矩阵的对角线元素则均为0。
在这里插入图片描述

那么根据我们对dp的理解,我们知道i不会超过j的,所以对于左下角矩阵实际上是不用填充的,我们要填充的只有右上角的矩阵。

对于dp[i][j]来说,我们现在能够拿到dp[i+1][j-1]的值(其中dp[i+1][j-1]表示i+1j-1范围内元素是否是回文的),那么dp[i][j]就有以下几种情况:

  • 第一种就是s[i] == s[j],在这种情况下,dp[i][j] = dp[i+1][j-1]
    在这里插入图片描述
  • 第二种就是s[i] != s[j]
    在这里插入图片描述

这种情况下,我们我们可以在i的右边加上c使得s[i+1]~s[j]成为一个回文串。或者在j的左边加上z,使得s[i]~s[j-1]成为一个回文串,之后取这两个步骤最少的那一步。那么假设现在我们在i的右边加上c了,那么此时我们只需要在这个回文串的右边(也就是j的右边)加上z就可以构成回文了。
在这里插入图片描述

代码呈现

class Solution {
public:/*** @brief leetcode提供的函数* * @param s 待构成回文的字符串* @return int 构成回文的最少步骤*/int minInsertions(string s) {int s_size = s.size();vector<vector<int>> dp(s_size,vector<int>(s_size,0));for(int i =s_size-2;i>=0;i--){for(int j = i+1;j<s_size;j++){if(s[i] == s[j]){dp[i][j] = dp[i+1][j-1];}else{dp[i][j] = min(dp[i+1][j],dp[i][j-1])+1;}}}return dp[0][s_size-1];}
};

参考文献

[1] labuladong的算法小抄[M].付东来

这篇关于LeetCode —— 1312. 让字符串成为回文串的最少插入次数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

python中字符串拼接的几种方法及优缺点对比详解

《python中字符串拼接的几种方法及优缺点对比详解》在Python中,字符串拼接是常见的操作,Python提供了多种方法来拼接字符串,每种方法有其优缺点和适用场景,以下是几种常见的字符串拼接方法,需... 目录1. 使用 + 运算符示例:优缺点:2. 使用&nbsjsp;join() 方法示例:优缺点:3

java字符串数字补齐位数详解

《java字符串数字补齐位数详解》:本文主要介绍java字符串数字补齐位数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java字符串数字补齐位数一、使用String.format()方法二、Apache Commons Lang库方法三、Java 11+的St

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

Golang中拼接字符串的6种方式性能对比

《Golang中拼接字符串的6种方式性能对比》golang的string类型是不可修改的,对于拼接字符串来说,本质上还是创建一个新的对象将数据放进去,主要有6种拼接方式,下面小编就来为大家详细讲讲吧... 目录拼接方式介绍性能对比测试代码测试结果源码分析golang的string类型是不可修改的,对于拼接字

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete