C语言 | Leetcode C语言题解之第516题最长回文子序列
题目:
题解:
int longestPalindromeSubseq(char* s) {int n = strlen(s);int dp[n][n];memset(dp, 0, sizeof(dp));for (int i = n - 1; i >= 0; i--) {dp[i][i] = 1;char c1 = s[i];for (int j = i + 1; j < n; j++) {char c2 = s[j];if (c1 == c2) {dp[i][j] = dp[i + 1][j - 1] + 2;} else {dp[i][j] = fmax(dp[i + 1][j], dp[i][j - 1]);}}}return dp[0][n - 1];
}