NC20252([SCOI2007]压缩 )

感受

思路








#include <bits/stdc++.h>

using namespace std;
typedef long long ll;
const int maxn = 100;
int dp[maxn][maxn][2];///dp[l][r][1]表示区间[l,r]中有M(插在pos后面)
int n;
char s[maxn];
void init(){
    for(int i = 1; i <= n; i++){
        dp[i][i][0] = 1; dp[i][i][1] = 2;
    }
}
bool check(int l, int mid, int r){
    for(int i = l, j = mid + 1; j <= r; i++, j++){
        if(s[i] != s[j]) return false;
    }
    return true;
}
int main(){
    scanf("%s", s + 1);
    n = strlen(s + 1);
    init();
    for(int len = 2; len <= n; len++){
        for(int l = 1, r; ; l++){
            r = l + len - 1; if(r > n) break;
            for(int mid = l; mid < r; mid++){
                if(!dp[l][r][0]) dp[l][r][0] = dp[l][mid][0] + r - mid;
                dp[l][r][0] = min(dp[l][r][0], dp[l][mid][0] + r - mid);
                if((r - mid) * 2 == len && check(l, mid, r)){
                    if(!dp[l][r][0]) dp[l][r][0] = dp[l][mid][0] + 1;
                    dp[l][r][0] = min(dp[l][r][0], dp[l][mid][0] + 1);
                }
                if(!dp[l][r][1]) dp[l][r][1] = min(dp[l][mid][0], dp[l][mid][1]) + 1 + min(dp[mid + 1][r][0], dp[mid + 1][r][1]);
                dp[l][r][1] = min(dp[l][r][1], min(dp[l][mid][0], dp[l][mid][1]) + 1 + min(dp[mid + 1][r][0], dp[mid + 1][r][1]));
            }
        }
    }
    printf("%d\n", min(dp[1][n][0], dp[1][n][1]));
    return 0;
}
全部评论

相关推荐

frutiger:逆天,我家就安阳的,这hr咋能说3k的,你送外卖不比这工资高得多?还说大厂来的6k,打发叫花子的呢?这hr是怎么做到说昧良心的话的
找工作时遇到的神仙HR
点赞 评论 收藏
分享
程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务