题目链接

小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希望知道其中最短的表示方法长度是多少。

----------------------------------------------------------------------------------------------------------------

dp[i][j] 代表从i到j(包括j)的最短长度,则:

dp[i][j] = MIN{

j - i + 1;

dp[i][k] + 2 + (j-i)/(k-i)的位数;   %% BEST(ABABAB) = 3(AB)

dp[i][k] + dp[k+1][j];   %%  BEST(AAAAAAAAAABABABCCD) = BEST(AAAAAAAAA) + BEST(ABABABCCD)

}

  1. #include <set>
  2. #include <map>
  3. #include <stack>
  4. #include <queue>
  5. #include <cmath>
  6. #include <vector>
  7. #include <string>
  8. #include <cstdio>
  9. #include <cstring>
  10. #include <cstdlib>
  11. #include <iostream>
  12. #include <algorithm>
  13.  
  14. #define MAX(a,b) ((a)>=(b)?(a):(b))
  15. #define MIN(a,b) ((a)<=(b)?(a):(b))
  16. #define OO 0x0fffffff
  17. using namespace std;
  18. typedef long long LL;
  19.  
  20. const int N = 128;
  21. char str[N];
  22. int dp[N][N];
  23.  
  24. int contains(const char *a,const char *b,int lenoa,int lenob){
  25. if(lenoa<lenob) return -1;
  26. if(lenoa%lenob) return -1;
  27. for(int i=0;i<lenoa;i++){
  28. if(a[i]!=b[i%lenob]) return -1;
  29. }
  30. return lenoa/lenob;
  31. }
  32. int get(int data){
  33. int ret = 0;
  34. while(data>0){
  35. data/=10;
  36. ret++;
  37. };
  38. return ret;
  39. }
  40. int main(){
  41. int n;
  42. for(cin>>n;n--;){
  43. scanf("%s",str);
  44. int len = strlen(str);
  45. for(int i=0;i<len;i++) for(int j=i;j<len;j++) dp[i][j] = j-i+1;
  46.  
  47. for(int stride=1;stride<len;++stride){
  48. for(int i=0;i+stride<len;++i){
  49. for(int j=0;j<stride;++j){
  50. dp[i][i+stride] = MIN(dp[i][i+stride],(dp[i][i+j]+dp[i+j+1][i+stride]));
  51. int cnt = contains(str+i,str+i,stride+1,j+1);
  52. if(cnt>0){
  53. dp[i][i+stride] = MIN(dp[i][i+stride],get(cnt)+2+dp[i][i+j]);
  54. }
  55. }
  56. }
  57. }
  58. printf("%d\n",dp[0][len-1]);
  59. }
  60. return 0;
  61. }

hiho160周 - 字符串压缩,经典dp的更多相关文章

  1. poj1458 求最长公共子序列 经典DP

    Common Subsequence Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 45763   Accepted: 18 ...

  2. HDU 1003 Max Sum --- 经典DP

    HDU 1003    相关链接   HDU 1231题解 题目大意:给定序列个数n及n个数,求该序列的最大连续子序列的和,要求输出最大连续子序列的和以及子序列的首位位置 解题思路:经典DP,可以定义 ...

  3. POJ 3254 压缩状态DP

    题意:一个矩形网格,可以填0或1, 但有些位置什么数都不能填,要求相邻两个不同时为1,有多少种填法.矩形大小最大 12*12. 压缩状态DP大多有一个可行的state的范围,先求出这个state范围, ...

  4. 基于Zlib算法的流压缩、字符串压缩源码

    原文:基于Zlib算法的流压缩.字符串压缩源码 Zlib.net官方源码demo中提供了压缩文件的源码算法.处于项目研发的需要,我需要对内存流进行压缩,由于zlib.net并无相关文字帮助只能自己看源 ...

  5. php字符串压缩

    在PHP中偶尔遇到字符串的压缩,比如一个长字符串,数据库开始设计的字段存不下,但是又不想改数据库字段存储长度,就可以用压缩的方式降低数据字段字符串的长度数量级,把几百个字符的字符串压缩到几十个字符.总 ...

  6. 字符串压缩 stringZip

    1,题目描述 通过键盘输入一串小写字母(a~z)组成的字符串.请编写一个字符串压缩程序,将字符串中连续出席的重复字母进行压缩,并输出压缩后的字符串.压缩规则:1. 仅压缩连续重复出现的字符.比如字符串 ...

  7. ruby直接字符串压缩与解压缩

    ruby2.1.3的核心类中包含了Zlib库,其中的Zlib模块包含了对字符串压缩和解压的方法: irb(main):180:0> Zlib.class => Module irb(mai ...

  8. 记录新项目中遇到的技术及自己忘记的技术点【DES加密解密,MD5加密,字符串压缩、解压,字符串截取等操作】

    一.DES加密.解密 #region DES加密解密 /// <summary> /// 进行DES加密 /// </summary> /// <param name=& ...

  9. NYOJ - 矩形嵌套(经典dp)

    矩形嵌套时间限制:3000 ms | 内存限制:65535 KB 描述 有n个矩形,每个矩形可以用a,b来描述,表示长和宽.矩形X(a,b)可以嵌套在矩形Y(c,d)中当且仅当a<c,b< ...

随机推荐

  1. 视图 Model转集合

    @{    Layout = null;}@using MvcApplication2.Models <!DOCTYPE html> <html><head>    ...

  2. 日志记录~log4.net

    1. 添加Log4net引用 2. 添加配置文件 Log.config <?xml version="1.0" encoding="utf-8"?> ...

  3. Vue.js 2.x Development Build With Hot Reloading For External Server (using Webpack template)

    This article assuming you created your project using webpack template. vue init webpack <PROJECT_ ...

  4. ListView的Item动画

    1.效果图 2.需求就是点击item歌曲时,实现一种飞入到预约按钮处的效果 3.思路:在布局文件中加入了一个条目布局,和listView的item一样,点击listView的item时,使用给条目布局 ...

  5. signature验证/salt验证/token验证的作用

    1.salt验证: salt是随机生成的一串字符,salt验证的作用是将生成的salt与加密的密码密文拼接后再次加密存储  这样可以是存储在数据库中的密码更加安全 2.signature验证: I.将 ...

  6. QQ自动登录里的一些控件知识

    在这个程序里面有个读取计算机指定文件的知识: private void button2_Click(object sender, EventArgs e) { openFileDialog1.Show ...

  7. GCC中的弱符号与强符号

    GCC中的弱符号与强符号 我们经常在编程中碰到一种情况叫符号重复定义.多个目标文件中含有相同名字全局符号的定义,那么这些目标文件链接的时候将会出现符号重复定义的错误.比如我们在目标文件A和目标文件B都 ...

  8. 【AnjularJS系列4 】 — 单个页面加载多个ng-App

    第四篇,插播, 单个页面加载多个ng-App 在写范例的时候发现的问题 一个页面有多个ng-app,angular只会处理第一个ng-app 需要加载两个ng-app,需要进行手动加载: angula ...

  9. ZBrush破解版下载,ZBrush中文版下载

    11月11日这个令人兴奋的日子又来了.没错,“双十一”所有网购达人狂欢的日子.但是ZBrush却让心心念念的小伙伴们失望了一把,本以为双十一期间会有相关活动的,结果,官方并未提及,事实上,ZBrush ...

  10. ZBrush软件特性之Marker标记调控板

    在ZBrush®中使用Marker标记调控板来记忆物体属性,因此能在任何时间回到标记并使用它给其他物体或改变物体作为参考点. ZBrush软件下载:http://pan.baidu.com/s/1sl ...