标签:== include 回文 code 问题 clu too 状态转移方程 滚动数组
状态转移方程如下:
当i > j时,dp[i,j]= 0。
当i = j时,dp[i,j] = 1。
当i < j并且str[i] == str[j]时,dp[i][j] = dp[i+1][j-1]+2;
当i < j并且str[i] ≠ str[j]时,dp[i][j] = max(dp[i][j-1],dp[i+1][j]); // 由短区间转移到长区间
然后由于状态第一维只涉及到i和i+1,所以可以用滚动数组优化一下空间。
#include <cstdio>// 滚动的就懒的写了2333 int main() { for(int l=2;i<=n;i++) { for(int i=1;i+l-1<=n;i++) { int j=i+l-1; if(s[i]==s[j]) dp[i][j]=dp[i+1][j-1]+2; else dp[i][j]=max(dp[i+1][j],dp[i][j-1]); } } }
标签:== include 回文 code 问题 clu too 状态转移方程 滚动数组
原文地址:http://www.cnblogs.com/z1141000271/p/7449930.html