给定一个字符串 s ,找到其中最长的回文子序列,并返回该序列的长度。可以假设 s 的最大长度为 1000 。
示例 1: 输入: "bbbab" 输出: 4 一个可能的最长回文子序列为 "bbbb"。
示例 2: 输入:"cbbd" 输出: 2 一个可能的最长回文子序列为 "bb"。
#include <stdio.h>
#include <stdlib.h>
#include "string.h"
#define max(a, b) (((a) > (b)) ? (a) : (b))
int maxLen(char* str1, int strSize1){
int dp[strSize1+1][2];
int result=0;
for (int i = 0; i < strSize1-1; ++i) {
dp[i][i]=1;
}
for (int i = strSize1-1; i >= 0; --i) {
for (int j = i+1; j < strSize1; ++j) {
if (str1[i] == str1[j]){
dp[i][j]=dp[i+1][j-1]+2;
}
else
dp[i][j] = max(dp[i+1][j],dp[i][j-1]);
}
}
printf("%d ",dp[0][strSize1-1]);
}
int main()
{
char str1[]="bbbab";
maxLen(str1,5);
return 0;
}