Leetcode 132 Solution

This article provides solution to leetcode question 132 (palindrome-partitioning-ii)

https://leetcode.com/problems/palindrome-partitioning-ii

Solution

class Solution { public: int minCut(string s) { if (s.size() == 0) return 0;
vector<int> dp(s.size(), INT_MAX); bool ispar[s.size()][s.size()];
memset((void*)ispar, 0, s.size() * s.size());
for (int j = 0; j < s.size(); j++) { for (int i = 0; i <= j; i++) { if (s[i] == s[j]) ispar[i][j] = j - 1 <= i + 1 || ispar[i + 1][j - 1]; } }
for (int i = 0; i < s.size(); i++) { for (int j = 0; j <= i; j++) { if (ispar[j][i]) dp[i] = min(dp[i], (j > 0 ? dp[j - 1] + 1 : 1)); } }
return dp.back() - 1; } };