首页 > 其他分享 >P1435 [IOI2000] 回文字串

P1435 [IOI2000] 回文字串

时间:2024-05-08 17:11:39浏览次数:22  
标签:子串 lbs IOI2000 s1 int P1435 文字串 字符串 dp

原题链接

题解

1.把字符串倒过来,记作 \(S_1\) 其最大公共子串是回文串,所以这部分可以不用求,字符串长度减去最大公共子串的长度就是答案
2.怎么求最大公共子串的长度呢?
假设我们已经知道字符串a和字符串b及其所有子串的lbs,此时往字符串b末尾添加一个字符c变成字符串b1,而字符串a中以最后一个字符c的前一个字符为最后一个位置的子串a1,则lbs(b1,a)=max(lbs(a1,b)+1,lbs(a,b))

code

#include<bits/stdc++.h>
using namespace std;
int dp[1005]={0};
int main()
{
    string s1,s2;//字符串型有很多强大的处理方法
    cin>>s1;
    int len=s1.length();
    for(int i=len-1;i>=0;i--)
    {
        s2.push_back(s1[i]);
    }

    for(int i=0;i<len;i++)
    {
        for(int j=len-1;j>=1;j--)
        {
            if(s2[j]==s1[i]) dp[j]=max(dp[j-1]+1,dp[j]);//由i-1和j-1  i-1和j 继承而来
        }
        if(s2[0]==s1[i]) dp[0]=1;
        for(int j=1;j<len;j++) dp[j]=max(dp[j],dp[j-1]);//由i和j-1继承而来
    }

    cout<<len-dp[len-1];
    return 0;
}

标签:子串,lbs,IOI2000,s1,int,P1435,文字串,字符串,dp
From: https://www.cnblogs.com/pure4knowledge/p/18180272

相关文章

  • 洛谷题单指南-动态规划2-P1435 [IOI2000] 回文字串
    原题链接:https://www.luogu.com.cn/problem/P1435解题思路:方法1:回文字串的特点是,正着读、反着读是一样的换一个思路,对于一个字符串s,正序、逆序公共的部分就是已经是回文的部分,剩余的部分就是要插入的字符所以,问题转换为,计算一个字符串正序、逆序的最长公共子串,然后剩下的长度......
  • P1435 [IOI2000] 回文字串
    题目:链接:https://www.luogu.com.cn/problem/P1435观察到:在里面插入字符不会影响外面的配对所以以dp[i][j]记录字符串s下标从i到j变化到回文串步数,那么递推公式:if(s[i]==s[j])dp[i][j]=dp[i+1][j-1];elsedp[i][j]=min(dp[i+1][j],dp[i][j-1])+1;就是说如果最外面能......
  • 回文字串
    回文串一般可以考虑把串倒过来思考问题对一个给定的串,我们将其倒序,设其长度为\(l\),求出原串和倒序的串的LCS,设长度为\(x\),则答案为\(l-x\)证明:我们假设已经获得了最终的回文串,然后我们将这个回文串倒序,那么肯定这个回文串与这个原串是相等的以样例为例其中红色字符是添加的......
  • 回文字串
    描述   给定一个字符串,输出所有长度至少为2的回文子串。   回文子串即从左往右输出和从右往左输出结果是一样的字符串,   比如:abba,cccdeedccc都是回文字符串。输入   一个字符串,由字母或数字组成。长度500以内。输出   输出所有的回文子串,每个子串一行。   ......
  • [IOI2000] 邮局
    [IOI2000]邮局题目描述高速公路旁边有一些村庄。高速公路表示为整数轴,每个村庄的位置用单个整数坐标标识。没有两个在同样地方的村庄。两个位置之间的距离是其整数坐标差的绝对值。邮局将建在一些,但不一定是所有的村庄中。为了建立邮局,应选择他们建造的位置,使每个村庄与其最近......
  • 决策单调性优化DP 学习笔记 & P4767 [IOI2000] 邮局 题解
    0.题面题目描述高速公路旁边有一些村庄。高速公路表示为整数轴,每个村庄的位置用单个整数坐标标识。没有两个在同样地方的村庄。两个位置之间的距离是其整数坐标差的绝对值。邮局将建在一些,但不一定是所有的村庄中。为了建立邮局,应选择他们建造的位置,使每个村庄与其最近的邮局......
  • [IOI2000] 邮局
    题目描述高速公路旁边有一些村庄。高速公路表示为整数轴,每个村庄的位置用单个整数坐标标识。没有两个在同样地方的村庄。两个位置之间的距离是其整数坐标差的绝对值。邮局将建在一些,但不一定是所有的村庄中。为了建立邮局,应选择他们建造的位置,使每个村庄与其最近的邮局之间的距......
  • 最长回文字串之暴力解法
    最长回文字串是一个典型的算法问题,首先要搞清楚什么是回文。回文,故名思义就是对称的文字,比如“ABA”,比如“ABABC”中的“AB“。题目如下:给你一个字符串s,找到s中最长......
  • [IOI2000]邮局 题解
    简要题意线段上有\(V\)个村庄,现在要建\(P\)个邮局,使每个村庄到最近的邮局的距离之和最小。50分做法设\(dp[i][j]\)表示第一个村庄到第\(i\)个村庄,建了\(j\)个......
  • Codeforces Round #837 (Div. 2)D (最大回文字串+树)
    题目链接:D.Hossamand(sub-)palindromictree题目描述给定一颗有n(n<=2e3)个顶点的树,每个顶点有一个点权(字符),定义s(u,v)为从u到v的简单路径所经过的点权形成的字符......