区间dp-基础题目3(永别)

题目链接

1 解题思路

这道题我们可以把整个字符串的大区间拆分成小区间,然后让相邻的两个小区间拼起来,如果左边小区间的第一个字符和右边小区的的最后一个字符相同,就可以选择它俩,再加上他们之间的字符能构成回文串的最大长度;如果不同,就选左边小区间和右边小区间的较大者。

这就不难想到区间dp: d p l r dplr dplr表示区间 l , r l,r l,r的字符串构成的最长回文串的长度。初始化全部元素为0, d p i i = 1 dpii=1 dpii=1。三种循环,第一层枚举区间长度,第二层枚举左右区间端点,第三层枚举区间的切割点(大区间切割成两个小区间,按照前面的策略更新 d p dp dp值)。

2 AC Code

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,dp[1005][1005];
string s;
int main(){
	cin>>n;
	cin>>s;
	for(int i=1;i<=n;i++) dp[i][i]=1;
	for(int lenn=2;lenn<=n;lenn++){
		for(int l=1,r=l+lenn-1;r<=n;l++,r++){
			if(s[l-1]==s[r-1]){
				if(r-l<=1) dp[l][r]=2;
				else dp[l][r]=max(dp[l][r],2+dp[l+1][r-1]);
			}
			for(int k=l;k<r;k++)
				dp[l][r]=max(dp[l][r],max(dp[l][k],dp[k+1][r]));
		}
	}
	cout<<dp[1][n];
	return 0;
}
相关推荐
周末也要写八哥2 小时前
有向图Hierholzer算法的另一种实现
算法
bIo7lyA8v2 小时前
算法调优中的性能回归与基准测试分析的技术8
算法·数据挖掘·回归
有点。2 小时前
C++贪心算法二(练习题)
c++·算法·贪心算法
西安邮电大学2 小时前
贪心算法详细讲解
java·后端·其他·算法·面试
开源Z2 小时前
LeetCode 135 · 分发糖果:两次扫描,先左后右取最大
算法·leetcode
坚果派·白晓明2 小时前
鸿蒙 PC 应用集成 libhv 鸿蒙化三方库 —— AtomCode + Skills 驱动的高效集成实践
c语言·c++·ai编程·harmonyos·atomcode
触底反弹2 小时前
拷个 .exe 到新电脑就跑不起来?你缺的不是文件,是对链接的理解
c++·windows·操作系统
装不满的克莱因瓶3 小时前
掌握生成对抗网络(GAN)的优化目标与评估指标——从博弈函数到生成质量衡量体系
人工智能·python·深度学习·算法·机器学习
技术小黑3 小时前
CNN算法实战系列06 | InceptionV1实现猴痘病识别
深度学习·算法·cnn·inceptionv1