【Link】:

【Description】



你能对字符串进行压缩的操作;

即把连续出现的相同的子串改成它出现的次数+这个最基本的字符串的形式;

问你这个字符串最短能被压缩得多短;

【Solution】



设f[i][j]表示,i..j这一段最短能压缩得多短;

d[i][j]表示i..j这一段最短的形式压缩成的字符串是什么;

对于一段i..j

有两种可能

1.是两个压缩串合并起来的;

2.自己构成一个压缩串

对于第一种,枚举间断点;

对于第二种,看看最短的母串是什么,用最短的母串构造压缩;

看看间断点自己构成重复的,哪一种更优;

选择最优的就好;

构造的时候,里面的东西也要是被压缩过的,因为压缩可以嵌套



【NumberOf WA】



0



【Reviw】



这是一种模型;

即是由两个串并在一起,还是自己组成压缩串.

题目中所给的定义很有用.



【Code】

#include <bits/stdc++.h>
using namespace std;
const int N = 100;
const int INF = 0x3f3f3f3f; string s,d[N+10][N+10];
int f[N+10][N+10];
int n; int ok(int l,int r){
for (int i = 1;i <= r-l;i++)
if ( (r-l+1)%i==0){
bool ok = true;
for (int j = l;j+i <= r;j++)
if (s[j]!=s[j+i])
ok = false;
if (ok) return i;
}
return 0;
} int dfs(int l,int r)
{
if (f[l][r]!=-1) return f[l][r];
if (l==r){
f[l][r] = 1;
d[l][r]="";d[l][r] += s[l];
return f[l][r];
}
int mi = INF,pos;
for (int i = l;i <= r-1;i++){
int temp = dfs(l,i) + dfs(i+1,r);
if (temp < mi){
mi = temp;
pos = i;
}
}
d[l][r] = d[l][pos]+d[pos+1][r];
int len = ok(l,r);
if (len){
int tlen = (r-l+1)/len;
ostringstream ts;
ts << tlen;
string temp = ts.str();
temp+="("+d[l][l+len-1]+")";
if ((int)temp.size()<mi){
d[l][r] = temp;
mi = (int) temp.size();
}
}
return f[l][r] = mi;
} int main(){
//freopen("F:\\rush.txt","r",stdin);
ios::sync_with_stdio(false);
while (cin >> s){
n = s.size();
s = ' '+s;
memset(f,-1,sizeof f);
dfs(1,n);
cout << d[1][n] <<endl;
}
return 0;
}

【Uva 1630】Folding的更多相关文章

  1. 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵

    偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...

  2. 【贪心+中位数】【UVa 11300】 分金币

    (解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...

  3. 【UVa 10881】Piotr's Ants

    Piotr's Ants Porsition:Uva 10881 白书P9 中文改编题:[T^T][FJUT]第二届新生赛真S题地震了 "One thing is for certain: ...

  4. 【UVa 116】Unidirectional TSP

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  5. 【UVa 1347】Tour

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  6. 【UVA 437】The Tower of Babylon(记忆化搜索写法)

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  7. 【uva 1025】A Spy in the Metro

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  8. 【POJ 2176】Folding

    [原题链接]传送门 [题面大意] 一个字符串,可以将它改写成循环节带括号的形式进行压缩,输出压缩长度最小的字符串. [题解思路] 1.没思路没思路,不知道怎么乱搞,大概就可以想到动态规划. 2.套路区 ...

  9. 【Uva 11584】Partitioning by Palindromes

    [Link]:https://cn.vjudge.net/contest/170078#problem/G [Description] 给你若干个只由小写字母组成的字符串; 问你,这个字符串,最少能由 ...

随机推荐

  1. Mysql信息数据库:Information_schema

    1. Information_schema information_schema是mysql的信息数据库. 通过该库能够查看mysql以下的数据库,表.权限等信息. 在数据库中会默认生成这个库.inf ...

  2. Golang 学习笔记 目录总结

    - 基础: 下载安装 声明变量的方法 数据的三种基础类型:bool,数字,string 数据类型:数组和切片 数据类型:Maps 条件判断以及循环 函数 包管理 package 指针 结构体 - 初步 ...

  3. Android项目实战(五十五):部分机型点击home再点图标进入程序不保留再之前界面的问题

    解决办法: 1.在基类Activity中 添加方法 @Override public boolean moveTaskToBack(boolean nonRoot) { return super.mo ...

  4. 数据绑定的知识点<%%>,<%#%>,<%=%>

    1.<% %>用来绑定后台代码 如: < % for(int i=0;i<100;i++) { Reaponse.Write(i.ToString()); } %> 2. ...

  5. German Collegiate Programming Contest 2015(第三场)

    Divisions David is a young boy and he loves numbers. Recently he learned how to divide two numbers.D ...

  6. git新克隆代码的时候ssh协议

  7. HDU-1023 Train Problem II 卡特兰数(结合高精度乘除)

    题目链接:https://cn.vjudge.net/problem/HDU-1023 题意 卡特兰数的应用之一 求一个长度为n的序列通过栈后的结果序列有几种 思路 一开始不知道什么是卡特兰数,猜测是 ...

  8. js 快捷键设置

    function hotkey() { var a=window.event.keyCode; if((a==65)&&(event.ctrlKey)) { alert("你 ...

  9. Unity C# 关于设计模式的思考

    一.当你的项目发现有如下问题之一时,就需要考虑重构代码,可能会有某种模式适合. 1.代码无法进行单元测试. 2.需求的变动总是导致代码的变动. 3.有重复代码的存在. 4.继承层次过多. 5.隐藏的依 ...

  10. Unity调用Android的两种方式:其一、调用jar包

    unity在Android端开发的时候,免不了要调用Java:Unity可以通过两种方式来调用Android:一是调用jar.二是调用aar. 这篇文章主要讲解怎么从无到有的生成一个jar包,然后un ...