C++_回文串

news2024/11/13 10:12:21

目录

 回文子串

最长回文子串

 分割回文串 IV

 分割回文串 II

 最长回文子序列

 让字符串成为回文串的最少插入次数


 回文子串

647. 回文子串

思路,i  j表示改范围内是否为回文串,

②倒着遍历是为了取出dp[i + 1][j - 1]

③i j 只有一对,不会重复,其实就是遍历

参考代码

class Solution {
public:
    int countSubstrings(string s) {
        int n = s.size();
        vector<vector<bool>> dp(n, vector<bool>(n));
        int ret = 0;
        for(int i = n - 1; i >= 0; i--)
        {
            // dp[i][i] = true;
            // for(int j = i + 1; j < n; j++)
            // {
            //     if(s[i] == s[j])
            //         dp[i][j] = j - i > 1 ? dp[i + 1][j - 1] : true;
            //     if(dp[i][j]) ret++;//判断每一次
            // }
            for(int j = i; j < n; j++)
            {
                if(s[i] == s[j])
                    dp[i][j] = j - i > 1 ? dp[i + 1][j - 1] : true;//只有最后一层会越界,但是
                if(dp[i][j])
                    ret++;
            }

        }
        // return ret + n;
        return ret;
    }
};

最长回文子串

5. 最长回文子串

思路区间[i,  j] 是true时候再判断

参考代码

class Solution {
public:
    string longestPalindrome(string s) {
        int n = s.size();
        vector<vector<int>> dp(n, vector<int>(n));
        int maxlen = 1, begin = 0;
        for(int i = n - 1; i >= 0; i--)
        {
            dp[i][i] = true;
            for(int j = i + 1; j < n; j++)
            {
                if(s[i] == s[j])
                    dp[i][j] = j - i > 1 ? dp[i + 1][j - 1] : true;
                if(dp[i][j] && j - i + 1 > maxlen)
                    maxlen = j - i + 1, begin = i;
            }
        }
        return s.substr(begin, maxlen);
    }
};

 分割回文串 IV

1745. 分割回文串 IV

用区间[i, j]即可分成三段 ,只要i j 不同,三段必不相同

参考代码

class Solution {
public:
    bool checkPartitioning(string s) {
        int n = s.size();
        vector<vector<bool>> dp(n, vector<bool>(n));
        for(int i = n - 1; i >= 0; i--)
            for(int j = i; j < n; j++)
                if(s[i] == s[j])
                    dp[i][j] = j - i > 1 ? dp[i + 1][j - 1] : true;
        for(int i = 1; i <= n - 2; i++)
            for(int j = i; j <= n - 2; j++)
                if(dp[0][i - 1] && dp[i][j] && dp[j + 1][n - 1])
                    return true;
        return false;
    }
};

 分割回文串 II

132. 分割回文串 II

刚开始打算用dp[i, j]区间内需要的次数 ,发现逻辑就不对,以左右单个字符拎出来,在min剩下的,最小分割的位置很可能在中间某个位置;所以打算重新遍历数组,和139. 单词拆分的思路很像,[0, i] 区间存放的就是最小分割次数

参考代码

class Solution {
public:
    int minCut(string s) {
        // int n = s.size();
        // vector<vector<int>> dp(n, vector<int>(n));
        // for(int i = n - 1; i >= 0; i--)
        // {
        //     for(int j = i + 1; j < n; 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][n - 1];
        int n = s.size();
        vector<vector<bool>> dp(n, vector<bool>(n));
        for(int i = n - 1; i >= 0; i--)
            for(int j = i; j < n; j++)
                if(s[i] == s[j]) dp[i][j] = j - i > 1 ? dp[i + 1][j - 1] : true;
        vector<int> times(n, INT_MAX);
        times[0] = 0;
        for(int i = 1; i < n; i++)
        {
            if(dp[0][i]) times[i] = 0;
            else
                for(int j = 1; j <= i; j++)
                    if(dp[j][i])
                        times[i] = min(times[i], times[j - 1] + 1);
        }
        return times[n - 1];
    }
};

 最长回文子序列

516. 最长回文子序列

 

 因为[i ,j] 表示的是区间内的最长回文子序列,这里我不怎么能直接理解,这里的j每次往后走,应该是去尝试匹配s[i],那么有人会说s[i] 可能和[i + 1, j - 1] 区间内有匹配了,那么用s[j]去匹配,不就少了一个吗?其实不然,这时候中间不管是否和s[i]相同,【 s[i] ,中间字符,s[j] 】就是一个回文子序列,这样是最大的;如果不相等,因为说了,状态表示的是区间内的最长回文子序列,这时候去已经有的区间里面找最长的已知区间就是[i + 1, j] 和 [i , j + 1],那为什么不去[i, j] 里找,因为没有啊,这时候,dp[i][j]是左值呀

参考代码

class Solution {
public:
    int longestPalindromeSubseq(string s) {
        int n = s.size();
        vector<vector<int>> dp(n, vector<int>(n, 1));
        for(int i = n - 1; i >= 0; i--)
        {
            for(int j = i + 1; j < n; j++)
            {
                if(s[i] == s[j])
                    dp[i][j] = j - i > 1 ? dp[i + 1][j - 1] + 2 : j - i + 1;
                else
                    dp[i][j] = max(dp[i + 1][j], dp[i][j - 1]);
            }
        }
        return dp[0][n - 1];
    }
};

 让字符串成为回文串的最少插入次数

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

 

 dp表示的是区间[i,  j] 内需要添加的最小次数,同样的道理,如果不相等就是去消除s[i] 或者s[j],消除伴随着 +1,也就是dp[i][j] = min(dp[i][j - 1], dp[i + 1][j]) + 1,你可能会感觉不对,  有可能是min(dp[i][j - 2], dp[i + 2][j])那么随之后面就要+2,但是这个时候可能s[i] 和s[j - 1]是相等的啊,那么就多添加了一个字符

参考代码

class Solution {
public:
    int minInsertions(string s) {
    int n = s.size();
        vector<vector<int>> dp(n, vector<int>(n));
        for(int i = n - 1; i >= 0; i--)
        {
            for(int j = i + 1; j < n; 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][n - 1];
    }
};

总结:通过区间[i,  j]来表示每个区间是否为回文串 ,是的话在进行怎样怎样的操作

我的错误发生: i总是写错i++, 注意力不集中

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

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

相关文章

每天上万简历,录取不到1%!阿里腾讯的 offer 都给了哪些人?

三月天杨柳醉春烟~正是求职好时节~ 与去年秋招的冷淡不同&#xff0c;今年春招市场放宽了许多&#xff0c;不少企业纷纷抛出橄榄枝&#xff0c;各大厂的只差把“缺人”两个字写在脸上了。 字节跳动技术方向开放数10个类型岗位&#xff0c;研发需求占比60%&#xff0c;非研发新增…

【数据结构】双向奔赴的爱恋 --- 双向链表

关注小庄 顿顿解馋๑ᵒᯅᵒ๑ 引言&#xff1a;上回我们讲解了单链表(单向不循环不带头链表)&#xff0c;我们可以发现他是存在一定缺陷的&#xff0c;比如尾删的时候需要遍历一遍链表&#xff0c;这会大大降低我们的性能&#xff0c;再比如对于链表中的一个结点我们是无法直接…

C/C++ 语言中的 ​if...else if...else 语句

C/C 语言中的 ​if...else if...else 语句 1. if statement2. if...else statement3. if...else if...else statementReferences 1. if statement The syntax of the if statement is: if (condition) {// body of if statement }The code inside { } is the body of the if …

《剑指 Offer》专项突破版 - 面试题 93 : 最长斐波那契数列(C++ 实现)

题目链接&#xff1a;最长斐波那契数列 题目&#xff1a; 输入一个没有重复数字的单调递增的数组&#xff0c;数组中至少有 3 个数字&#xff0c;请问数组中最长的斐波那契数列的长度是多少&#xff1f;例如&#xff0c;如果输入的数组是 [1, 2, 3, 4, 5, 6, 7, 8]&#xff0…

代码随想录训练营Day33:● 1005.K次取反后最大化的数组和 ● 134. 加油站 ● 135. 分发糖果

1005.K次取反后最大化的数组和 题目链接 https://leetcode.cn/problems/maximize-sum-of-array-after-k-negations/ 题目描述 思路 1、自己的想法 class Solution {public int largestSumAfterKNegations(int[] nums, int k) {sorted(nums);//遇到 <0 的 &#xff0c;就…

CTF题型 nodejs(1) 命令执行绕过典型例题

CTF题型 nodejs(1) 命令执行绕过 文章目录 CTF题型 nodejs(1) 命令执行绕过一.nodejs中的命令执行二.nodejs中的命令绕过1.编码绕过2.拼接绕过3.模板字符串4.Obejct.keys5.反射6.过滤中括号的情况典型例题1.[GFCTF 2021]ez_calc2.[西湖论剑 2022]Node Magical Login 一.nodejs中…

黑马头条day5总结

1、surefire-reports for the individual test results. 借鉴&#xff1a;【已解决】surefire-reports for the individual test results.-CSDN博客 Please refer to D:\javashizhan01\heima-leadnews\heima-leadnews-service\heima-leadnews-article\target\surefire-report…

手撕算法-数组中的第K个最大元素

描述 分析 使用小根堆&#xff0c;堆元素控制在k个&#xff0c;遍历数组构建堆&#xff0c;最后堆顶就是第K个最大的元素。 代码 class Solution {public int findKthLargest(int[] nums, int k) {// 小根堆PriorityQueue<Integer> queue new PriorityQueue<>…

k8s入门到实战(六)—— ConfigMap介绍

ConfigMap configmap 是 k8s 中的资源对象&#xff0c;用于保存非机密性的配置的&#xff0c;数据可以用 kv 键值对的形式保存&#xff0c;也可通过文件的形式保存。 什么是 configmap 在 k8s 中&#xff0c;ConfigMap 是一种用于存储应用程序配置数据的对象。它允许将配置信…

【python】Jupyter Notebook 修改默认路径

文章目录 一、修改前&#xff08;一&#xff09;问题&#xff08;二&#xff09;修改前的默认路径 二、修改配置文件、更改路径&#xff08;一&#xff09;找到配置文件并打开&#xff08;二&#xff09;创建目标文件夹、得到新的路径&#xff08;三&#xff09;修改配置文件 三…

小目标检测篇 | YOLOv8改进之GSConv + Slim Neck提升小目标检测效果

前言:Hello大家好,我是小哥谈。在文章中,作者提出了一种新方法GSConv来减轻模型的复杂度并保持准确性。GSConv可以更好地平衡模型的准确性和速度。并且,提供了一种设计范式Slim Neck,以实现检测器更高的计算成本效益。实验过程中,与原始网络相比,改进方法获得了最优秀的…

nginx--解决响应头带Set-Cookie导致的验证失败

解决响应头带Set-Cookie导致的验证失败 前言给nginx.conf 设置Secure配置完成后会发现cookie就不会发生变化了 前言 在用nginx做代理的时候&#xff0c;会发现nginx在访问不同ip请求的时候会带setCookie 导致后端就是放开cookie验证&#xff0c;在访问玩这个链接他更新了cooki…

成都爱尔胡建斌院长强调黄斑病变是眼睛哪儿出了问题

黄斑位于眼球内部的眼底的视网膜区域&#xff0c;处于人眼的光学中心区&#xff0c;是视力轴线的投影点。它是人眼视网膜中央视觉细胞最集中的部位。黄斑中心多为锥形细胞&#xff0c;对明暗不敏感&#xff0c;对色敏感。黄斑外围多为柱形细胞&#xff0c;对明暗敏感,对色几乎不…

javaWeb私人牙科诊所管理系统

一、摘要 随着科技的飞速发展&#xff0c;计算机已经广泛的应用于各个领域之中。在医学领域中&#xff0c;计算机主要应用于两个方面&#xff1a;一是医疗设备智能化&#xff0c;以硬件为主。另一种是病例信息管理系统&#xff08;HIS&#xff09;以软件建设为主&#xff0c;以…

深度学习pytorch——减少过拟合的几种方法(持续更新)

1、增加数据集 2、正则化(Regularization) 正则化&#xff1a;得到一个更加简单的模型的方法。 以一个多项式为例&#xff1a; 随着最高次的增加&#xff0c;会得到一个更加复杂模型&#xff0c;模型越复杂就会更好的拟合输入数据的模型&#xff08;图-1&#xff09;&#…

【数据结构与算法】用染色法判定二分图

问题描述 给定一个 n 个点 m 条边的无向图&#xff0c;图中可能存在重边和自环。 请你判断这个图是否是二分图。 输入格式 第一行包含两个整数 n 和 m。 接下来 m 行&#xff0c;每行包含两个整数 u 和 v&#xff0c;表示点 u 和点 v 之间存在一条边。 输出格式 如果给定图…

js中如何用点击地图获取经纬度

要实现在地图上点击并获取被点击地址的经纬度&#xff0c;然后渲染至页面中的功能&#xff0c;你需要首先确保你使用的地图API支持点击事件&#xff0c;并且能够返回点击位置的经纬度。以高德地图&#xff08;AMap&#xff09;为例&#xff0c;你可以按照以下步骤实现这个功能&…

wma怎么转换成mp3?无损转换!

WMA&#xff08;Windows Media Audio&#xff09;文件格式诞生于微软公司的数字音频技术研发。由于其高压缩性能和较好的音质&#xff0c;在推出初期主要用于Windows Media Player等微软产品。然而&#xff0c;随着MP3格式的盛行&#xff0c;WMA的使用范围逐渐受到限制。 MP3文…

ES6 基础

文章目录 1. 初识 ES62. let 声明变量3. const 声明常量4. 解构赋值 1. 初识 ES6 ECMAScript6.0(以下简称ES6)是JavaScript语言的下一代标准&#xff0c;已经在2015年6月正式发布了。它的目标&#xff0c;是使得」JavaScript语言可以用来编写复杂的大型应用程序&#xff0c;成为…

MySQL 经典练习 50 题 (记录)

前言&#xff1a; 记录一下sql学习&#xff0c;仅供参考基本都对了&#xff0c;不排除有些我做的太快做错了。里面sql不存在任何sql优化操作&#xff0c;只以完成最后输出结果为目的&#xff0c;包含我做题过程和思路最后一行才是结果。 1.过程: 1.1.插入数据 /* SQLyog Ul…