描述


小Hi希望压缩一个只包含大写字母'A'-'Z'的字符串。他使用的方法是:如果某个子串 S 连续出现了 X 次,就用'X(S)'来表示。例如AAAAAAAAAABABABCCD可以用10(A)2(BA)B2(C)D表示。

此外,这种压缩方法是可以嵌套的,例如HIHOHIHOCODERHIHOHIHOCODER可以表示成2(2(HIHO)CODER)。

对于一个字符串 S ,合法的压缩表示可能有很多种。例如AAAAAAAAAABABABCCD还可以表示成9(A)3(AB)CCD。小Hi希望知道其中最短的表示方法长度是多少。

输入


第一行一个正整数 T (1 ≤ T ≤ 10),表示测试数据的组数。

以下 T 行每行一个字符串 S ,长度不超过100。

输出


对于每组数据,输出最短的表示方法的长度。

样例输入

  1. 3
  2. ABC
  3. AAAAAAAAAABABABCCD
  4. HIHOHIHOCODERHIHOHIHOCODER

样例输出

  1. 3
  2. 12
  3. 15

题解


dp[l][r]表示区间最短表示长度

边界:dp[l][l]=1

转移方程:

  1. mi=inf;
  2. For i=l .. r
  3. mi=Math.min(mi,dp(l,i)+dp(i+1,r));
  4. if(check(l,i,i+1,r)) mi=Math.min(mi,dp(l,i)+cacu((r-i)/(i-l+1)+1)+2);
  5. End For
  6. dp[l][r]=mi;
  7. cacu(x) 为计算x的长度

区间DP写成记忆化搜索是很方便的

  1. import java.io.*;
  2. import java.util.*;
  3. public class Main {
  4. static final int N=(int)1e5+10;
  5. static int dp[][]=new int[105][105];
  6. static String str;
  7. static boolean check(int l1,int r1,int l2,int r2) {
  8. if((r2-l2+1)%(r1-l1+1)!=0) return false;
  9. for(int i=l2;i<=r2;i++) {
  10. if(str.charAt(i)!=str.charAt((i-l2)%(r1-l1+1)+l1)) return false;
  11. }
  12. return true;
  13. }
  14. static int cacu(int x) {
  15. int len=0;
  16. while(x>0) {
  17. x/=10;
  18. len++;
  19. }
  20. return len;
  21. }
  22. static int solve(int l,int r) {
  23. if(l==r) return 1;
  24. if(dp[l][r]!=-1) return dp[l][r];
  25. int mi=(r-l+1)*3;
  26. for(int i=l;i<r;i++) {
  27. mi=Math.min(mi,solve(l,i)+solve(i+1,r));
  28. if(check(l,i,i+1,r)) mi=Math.min(mi,solve(l,i)+cacu((r-i)/(i-l+1)+1)+2);
  29. }
  30. return dp[l][r]=mi;
  31. }
  32. public static void main(String[] args){
  33. Scanner sc=new Scanner(new InputStreamReader(System.in));
  34. int T=sc.nextInt();
  35. StringBuilder ans=new StringBuilder();
  36. while(T--!=0) {
  37. for(int i=0;i<105;i++) {
  38. for(int j=0;j<105;j++) {
  39. dp[i][j]=-1;
  40. }
  41. }
  42. str=sc.next();
  43. ans.append(solve(0,str.length()-1)+"\n");
  44. }
  45. System.out.print(ans);
  46. sc.close();
  47. }
  48. }

【HIHOCODER 1320】压缩字符串(区间DP)的更多相关文章

  1. hihoCoder #1320 : 压缩字符串 区间dp

    /** 题目:hihoCoder #1320 : 压缩字符串 链接:https://hihocoder.com/problemset/problem/1320 描述 小Hi希望压缩一个只包含大写字母' ...

  2. hihocoder 1320 压缩字符串(字符串+dp)

    题解: 其实就是对应三种dp的转移方式 1.拼接类型 dp[i][j] = dp[i][c] + dp[c][j] 2.不变类型 dp[i][j] = j-i+1 3.重复类型(必须满足有k个循环节) ...

  3. hihocoder 1320 - 压缩字符串 - [hiho一下160周]

    这道题目可以说是一道非常好非常一颗赛艇的DP题了. 需要注意的是,其中情形3),字符串必然能完全转化为 N(str)形式,如果有N(str1)M(str2)等等另外样式,应该首先使用拼接形式对其进行划 ...

  4. [SCOI2007]压缩(动态规划,区间dp,字符串哈希)

    [SCOI2007]压缩 状态:设\(dp[i][j]\)表示前i个字符,最后一个\(M\)放置在\(j\)位置之后的最短字串长度. 转移有三类,用刷表法来实现. 第一种是直接往压缩串后面填字符,这样 ...

  5. 字符串折叠&压缩(区间DP)

    字符串折叠 题目描述 折叠的定义如下: 一个字符串可以看成它自身的折叠.记作S = S X(S)是X(X>1)个S连接在一起的串的折叠.记作X(S) = SSSS-S(X个S). 如果A = A ...

  6. 1068. [SCOI2007]压缩【区间DP】

    Description 给一个由小写字母组成的字符串,我们可以用一种简单的方法来压缩其中的重复信息.压缩后的字符串除了小 写字母外还可以(但不必)包含大写字母R与M,其中M标记重复串的开始,R重复从上 ...

  7. [SCOI2007]压缩(区间dp)

    神仙题,看了半天题解才看明白... 因为题目里说如果没有m,会自动默认m在最前面. 我们设计状态为dp[l][r][0/1]为在区间l到r中有没有m的最小长度. 转移:枚举我们要压缩的起点,dp[l] ...

  8. BZOJ1068 [SCOI2007]压缩 【区间dp】

    题目 给一个由小写字母组成的字符串,我们可以用一种简单的方法来压缩其中的重复信息.压缩后的字符串除了小 写字母外还可以(但不必)包含大写字母R与M,其中M标记重复串的开始,R重复从上一个M(如果当前位 ...

  9. bzoj 1068: [SCOI2007]压缩【区间dp】

    神区间dp 设f[l][r][0]为在l到r中压缩的第一个字符为M,并且区间内只有这一个M,f[l][r][0]为在l到r中压缩的第一个字符为M,并且区间内有两个及以上的M 然后显然的转移是f[i][ ...

  10. hihocoder 1829 - 压缩字符串 - [状压+暴力枚举][2018ICPC北京网络预赛B题]

    题目链接:https://hihocoder.com/problemset/problem/1829 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 Lara Croft, ...

随机推荐

  1. NowCoder小定律

    题目:https://www.nowcoder.com/pat/2/problem/259 #include <cstdio> #include <cstring> #incl ...

  2. oracle 查询用户权限

    查询用户和权限 select object_name,created from user_objects; 受权 grant select any table,create table,create ...

  3. DP HDOJ 5492 Find a path

    题目传送门 题意:从(1, 1)走到(n, m),每次往右或往下走,问(N+M−1)∑(Ai−Aavg)2 的最小值 分析:展开式子得到(N+M−1)∑(Ai2) - (∑(Ai))2的最小值.用普通 ...

  4. adb shell报错:error: insufficient permissions for device的解决办法

    1.错误描述 执行 adb shell 时,报错如下; error: insufficient permissions for device  2.解决办法 1,终端执行 lsusb 结果如下,注意绿 ...

  5. c#学习系列之装箱拆箱

    1.      装箱和拆箱是一个抽象的概念 2.      装箱是将值类型转换为引用类型 :拆箱是将引用类型转换为值类型       利用装箱和拆箱功能,可通过允许值类型的任何值与Object 类型的 ...

  6. EmitMapper系列之二:EmitMapper的使用小结

    EmitMapper的入门 EmitMapper引用 EmitMapper案例 最近公司开发项目前端使用一个js框架,后端使用ef,js前台读取的json采用实体的dto来进行生成. 在网上看到了Em ...

  7. 【学习笔记】深入理解js原型和闭包(6)——继承

    为何用“继承”为标题,而不用“原型链”? 原型链如果解释清楚了很容易理解,不会与常用的java/C#产生混淆.而“继承”确实常用面向对象语言中最基本的概念,但是java中的继承与javascript中 ...

  8. redis安装(windows)

    软件环境:由于redis只有linux版,而windows版是微软自己做的,最新版只到3.2.100(linux的版本已经到5.x) 1.1.1.  redis安装 首先去官网下载安装包 得到的安装文 ...

  9. git diff查看修改,出现^M换行问题

    通过命令git diff查看修改,出现^M换行问题,如图: 解决: git config --global core.whitespace cr-at-eol 换行符的问题: 提交时转换为LF,检出时 ...

  10. CENTOS6.4上KVM虚拟机环境搭建

    CENTOS6.4上KVM虚拟机环境搭建   关键词: KVM,虚拟机,windows7, VNC, 桥接网络,br0, SCSI, IDE   环境: host: CENTOS6.4 guest: ...