社区讨论
80求救
P4170[CQOI2007] 涂色参与者 4已保存回复 5
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 5 条
- 当前快照
- 1 份
- 快照标识符
- @locygsmt
- 此快照首次捕获于
- 2023/10/30 21:48 2 年前
- 此快照最后确认于
- 2023/11/05 08:10 2 年前
CPP
#include<cstdio>
#include<iostream>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=75;
char s[N];
int f[N][N];
int main(){
//freopen("a.in","r",stdin);
//freopen("a.out","w",stdout);
scanf("%s",s+1);
int n=strlen(s+1);
//if(s[n]=='\n')n--;
memset(f,0x7f,sizeof(f));
for(int i=1;i<=n;i++)f[i][i]=1;
for(int len=1;len<=n;len++){
for(int l=1;l+len<=n;l++){
int r=l+len;
if(s[r]==s[r-1]||s[r]==s[l])f[l][r]=min(f[l][r],f[l][r-1]);
else f[l][r]=min(f[l][r],f[l][r-1]+1);
if(s[l]==s[l+1]||s[l]==s[r])f[l][r]=min(f[l][r],f[l+1][r]);
else f[l][r]=min(f[l][r],f[l+1][r]+1);
}
}
printf("%d\n",f[1][n]);
return 0;
}
RT
交上去wa了两个点,都是比答案大1
回复
共 5 条回复,欢迎继续交流。
正在加载回复...