P4170 [CQOI2007]涂色很普通的区间dp,但是小fw我莫名wa了六个点
#include<bits/stdc++.h>
using namespace std;
string s;
int dp[1001][1001];
int main()
{
cin>>s;
int n=s.size()-1;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
dp[i][j]=1e9+7;
for(int i=1;i<=n;i++)
dp[i][i]=1;
for(int l=2;l<=n;l++)
for(int i=1,j=l;i<=n,j<=n;i++,j=i+l-1)
{
if(s[i]==s[j])
dp[i][j]=min(dp[i][j-1],dp[i+1][j]);
else
for(int k=i;k<j;k++)
dp[i][j]=min(dp[i][k]+dp[k+1][j],dp[i][j]);
}
cout<<dp[1][n]<<endl;
return 0;
}
求调,我觉得我这代码和题解只差变量名不一样了(