[SCOI2007]压缩 区间dp

时间:2022-09-27 22:51:37

明显是个区间dp,但是我区间dp就是个渣。。。

f[i][j]表示区间i到j最短的字符长度;假设前面加了个M,所以初始化f[i][i]=2;当然最开始是不算M的,所以f[1][1]=1;然后就可以区间dp了。        f[i][j]=min{f[i][j-1]+1};//从上一个加一更新过来(如果不存在重合的话)

if(a[i]==a[j]&&check(i,j))//判断是否有重合部分

f[i][j+j-i-1]=min(f[i][j+j-i-1],f[i][j-1]+1);//重合部分用R代替,所以要+1.注意好下标,最后再用一个dp合并就可以了。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
#define pos(i,a,b) for(int i=(a);i<=(b);i++)
char a[100],b[100];
int n;
int f[100][100];
int check(int i,int j)
{
    pos(k,1,j-i-1)
    {
       if(a[i+k]!=a[j+k])
        return 0;
    }
    return 1;
}
int main()
{
    memset(f,50,sizeof(f));
    scanf("%s",&b);
    n=strlen(b);
    pos(i,1,n)
      a[i]=b[i-1];
    //cout<<n;

    pos(i,1,n)
      f[i][i]=2;
    f[1][1]=1;
    pos(i,1,n)
      pos(j,i+1,n)
      {
         f[i][j]=min(f[i][j-1]+1,f[i][j]);
         if(a[i]==a[j]&&check(i,j))
           f[i][j+j-i-1]=min(f[i][j+j-i-1],f[i][j-1]+1);
      }
    pos(i,1,n)
      pos(j,i+1,n)
        pos(k,i,j-1)
          f[i][j]=min(f[i][j],f[i][k]+f[k+1][j]);
    cout<<f[1][n];
    //while(1);
    return 0;
}

  

[SCOI2007]压缩 区间dp的更多相关文章

  1. bzoj 1068 &lbrack;SCOI2007&rsqb;压缩 区间dp

    [SCOI2007]压缩 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 1644  Solved: 1042[Submit][Status][Discu ...

  2. B1068 &lbrack;SCOI2007&rsqb;压缩 区间dp

    这个题我状态想对了,但是转移错了...dp的代码难度都不大,但是思考含量太高了..不会啊,我太菜了. 其实这个题就是一个正常的区间dp,中间多了一个特判的转移就行了. 题干: Description ...

  3. 洛谷P2470 &lbrack;SCOI2007&rsqb;压缩&lpar;区间dp&rpar;

    题意 题目链接 Sol 神仙题Orz 考虑区间dp,如果我们只设\(f[l][r]\)表示\(s_{lr}\)被压缩的最小长度,而不去关心内部\(M\)分布的话,可能在转移的时候转移出非法状态 因此考 ...

  4. 【BZOJ-1068】压缩 区间DP

    1068: [SCOI2007]压缩 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 1001  Solved: 615[Submit][Status][ ...

  5. ACM学习历程—HDU1584 蜘蛛牌(动态规划 &amp&semi;&amp&semi; 状态压缩 &vert;&vert; 区间DP)

    Description 蜘蛛牌是windows xp操作系统自带的一款纸牌游戏,游戏规则是这样的:只能将牌拖到比她大一的牌上面(A最小,K最大),如果拖动的牌上有按顺序排好的牌时,那么这些牌也跟着一起 ...

  6. 状态压缩---区间dp第一题

    标签: ACM 题目 Gappu has a very busy weekend ahead of him. Because, next weekend is Halloween, and he is ...

  7. BZOJ1068 &lbrack;SCOI2007&rsqb;压缩 区间动态规划 字符串

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1068 题目概括 (其实是复制的) 给一个由小写字母组成的字符串,我们可以用一种简单的方法来压缩其中 ...

  8. 【BZOJ】1068&colon; &lbrack;SCOI2007&rsqb;压缩(dp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1068 发现如果只设一维的话无法转移 那么我们开第二维,发现对于前i个来说,如果确定了M在哪里,第i个 ...

  9. &lbrack;bzoj&rsqb; 1068 压缩 &vert;&vert; 区间dp

    原题 f[i][j][0/1]表示i-1处有一个M,i到j压缩后的长度,0/1表示i到j中有没有m. 初始为j-i+1 f[i][j][0]=min(f[i][j][0],f[i][k][0]+j-k ...

随机推荐

  1. c语言 指针与数组

    关键概念: 1.多个不同类型的指针可以对应同一个地址: 2.(&p)则是这样一种运算,返回一个指针,该指针的值是当时声明p 时开辟的地址,指针的类型是p的类型对应的指针类型: 3.(*p)操作 ...

  2. java并发:简单面试问题集锦

    多线程:Simultaneous Multithreading,简称SMT. 并行.并发 并行性(parallelism)指两个或两个以上的事件在同一时刻发生,在多道程序环境下,并行性使多个程序同一时 ...

  3. js常用函数、书写可读性的js、js变量声明&period;&period;&period;

    1.Array类型函数 array.concat(item...) 函数功能:关联数组,实现数组相加功能,但并不影响原先数组,concat返回新数组. array.join(separator) 函数 ...

  4. JavaWeb学习总结-07 Filter 学习和使用

    一 Filter简介 Filter也称之为过滤器,它是Servlet技术中最激动人心的技术,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态 ...

  5. C&num;项目打包后安装的桌面快捷方式图标怎么设置成自己想要的图标

    #项目打包后安装的桌面快捷方式图标怎么设置成自己想要的图标 2012-08-25 09:11匿名 | 浏览 3286 次  C#编程 C#项目用vs2005自带的工具打包后安装的桌面快捷方式图标怎么设 ...

  6. Codeforces Round &num;216 &lpar;Div&period; 2&rpar;解题报告

    又范低级错误! 只做了两题!一道还被HACK了,囧! A:看了很久!应该是到语文题: 代码:#include<iostream> #include<];    ,m2=;    ;i ...

  7. python基础&colon;三层循环

    三层循环基本演示: break_flag = False #标记1 break_flag2 = False #标记2 break_flag3 = False #标记3 while not break_ ...

  8. 将某个组中的账户移动到新的OU下

    将某个组中的账户移动到新的OU下 #定义组名 $groupname = "testg" #定义新的OU名称 $newou = "OU=oo,OU=Admins,dc=dd ...

  9. PHPCMS 标签与解析小记&lowbar;Jason

    Content模块下的标签解析:phpcms\modules\content\classes\content_tag.class.php 推荐位:public function position

  10. 6、Web应用程序中的安全向量 -- customErrors(适当的错误报告和堆栈跟踪)

    几乎所有的网站在开发过程中都在web.config文件中设置了特性<customErrors mode="off">. customErrors模式有3个可选的设置项: ...