最长回文子序列 - 动态规划

样题引导

所谓回文字符串,就是一个字符串,从左到右读和从右到左读是完全一样的,比如“aba”、“c”,对于一个字符串,可以通过删除某些字符而变成回文字符串,如“cabebaf”,删除’c’、’e’、‘f’后剩下子串“abba”就是回文字符串。

要求,给定任意一个字符串,字符串最大长度1000,计算出最长的回文子序列长度。

如“cabebaf”的回文串包括“c”、“aba”、“abba”等,最长回文子序列“abba”长度为4。
如“google”,输出2。
如“aBc,bAd”,输出2。

从样题入手分析

注意这里要求的是最长回文子序列。不是最长回文串。
最常用的手段当然是dfs。但dfs对于1000长度的字符串,肯定会超时。
因为有很多重叠的地方。
这里写图片描述
通过递归。重叠的地方如L(1,4)。
动态规划方法。
用牺牲空间换时间的方法,通过自下而上的方式记录子问题的最优解。

代码

#include <bits/stdc++.h>
#define _xx ios_base::sync_with_stdio(0);cin.tie(0);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值