【Uva 1630】Folding
【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的更多相关文章
- 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵
偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...
- 【贪心+中位数】【UVa 11300】 分金币
(解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...
- 【UVa 10881】Piotr's Ants
Piotr's Ants Porsition:Uva 10881 白书P9 中文改编题:[T^T][FJUT]第二届新生赛真S题地震了 "One thing is for certain: ...
- 【UVa 116】Unidirectional TSP
[Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【UVa 1347】Tour
[Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【UVA 437】The Tower of Babylon(记忆化搜索写法)
[题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【uva 1025】A Spy in the Metro
[题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【POJ 2176】Folding
[原题链接]传送门 [题面大意] 一个字符串,可以将它改写成循环节带括号的形式进行压缩,输出压缩长度最小的字符串. [题解思路] 1.没思路没思路,不知道怎么乱搞,大概就可以想到动态规划. 2.套路区 ...
- 【Uva 11584】Partitioning by Palindromes
[Link]:https://cn.vjudge.net/contest/170078#problem/G [Description] 给你若干个只由小写字母组成的字符串; 问你,这个字符串,最少能由 ...
随机推荐
- Mysql信息数据库:Information_schema
1. Information_schema information_schema是mysql的信息数据库. 通过该库能够查看mysql以下的数据库,表.权限等信息. 在数据库中会默认生成这个库.inf ...
- Golang 学习笔记 目录总结
- 基础: 下载安装 声明变量的方法 数据的三种基础类型:bool,数字,string 数据类型:数组和切片 数据类型:Maps 条件判断以及循环 函数 包管理 package 指针 结构体 - 初步 ...
- Android项目实战(五十五):部分机型点击home再点图标进入程序不保留再之前界面的问题
解决办法: 1.在基类Activity中 添加方法 @Override public boolean moveTaskToBack(boolean nonRoot) { return super.mo ...
- 数据绑定的知识点<%%>,<%#%>,<%=%>
1.<% %>用来绑定后台代码 如: < % for(int i=0;i<100;i++) { Reaponse.Write(i.ToString()); } %> 2. ...
- German Collegiate Programming Contest 2015(第三场)
Divisions David is a young boy and he loves numbers. Recently he learned how to divide two numbers.D ...
- git新克隆代码的时候ssh协议
- HDU-1023 Train Problem II 卡特兰数(结合高精度乘除)
题目链接:https://cn.vjudge.net/problem/HDU-1023 题意 卡特兰数的应用之一 求一个长度为n的序列通过栈后的结果序列有几种 思路 一开始不知道什么是卡特兰数,猜测是 ...
- js 快捷键设置
function hotkey() { var a=window.event.keyCode; if((a==65)&&(event.ctrlKey)) { alert("你 ...
- Unity C# 关于设计模式的思考
一.当你的项目发现有如下问题之一时,就需要考虑重构代码,可能会有某种模式适合. 1.代码无法进行单元测试. 2.需求的变动总是导致代码的变动. 3.有重复代码的存在. 4.继承层次过多. 5.隐藏的依 ...
- Unity调用Android的两种方式:其一、调用jar包
unity在Android端开发的时候,免不了要调用Java:Unity可以通过两种方式来调用Android:一是调用jar.二是调用aar. 这篇文章主要讲解怎么从无到有的生成一个jar包,然后un ...