本文共 741 字,大约阅读时间需要 2 分钟。
#includeusing namespace std;typedef long long ll;int n,dp[501][501],a[501];int main(){ scanf("%d",&n); for(int i=1;i<=n;++i) scanf("%d",&a[i]); memset(dp,0x3f,sizeof(dp)); for(int i=1;i<=n;++i) dp[i][i]=1; for(int len=2;len<=n;++len) { for(int l=1;l+len-1<=n;++l) { int r=l+len-1; if(l+1==r) dp[l][r]=((a[l]==a[r])?1:2); for(int k=l;k
记忆化:
#includeusing namespace std;typedef long long ll;int n,dp[501][501],a[501];const int inf=0x3f3f3f3f;int dfs(int l,int r){ if(l==r) return dp[l][r]=1; if(l>r) return 1; if(dp[l][r]!=inf) return dp[l][r]; int ans=inf; if(a[l]==a[r]) ans=min(ans,dfs(l+1,r-1)); for(int k=l;k
转载地址:http://sgewz.baihongyu.com/