POJ2176 Folding
POJ2176 Folding
描述
给定一个长度不超过100的字符串,求其“压缩”后长度最短的字符串。如有多个,输出任意即可。
其中对于一个字符串\(str\)的“压缩”\(F(str)\)定义如下:
当\(|str|=1\)时,有\(F(str)=str\),\(|F(str)|=1\)。
\(F(str_1+str_2)=F(str_1)+F(str_2)\)
\(X(str)\)是字符串\(\underbrace{str+str+\cdots+str}_X\)的压缩,且\(|X(str)|=\lfloor\lg X\rfloor+|str|+2\),即包含括号和数字本身。
如字符串
AAAAAAAAAABABABCCD
的最短压缩为9(A)3(AB)CCD
,长度由\(18\)降为\(12\)。注意2(C)
的长度为\(4\),不会比CC
更优。压缩可以嵌套。如
AAAAAAABAAAAAAAABA
可以压缩为2(7(A)BA)
。
思路
设\(F(l,r)\)表示合并字符串\(S_{l\cdots r}\)得到的最短长度。根据定义,字符串的压缩具有叠加性,得到:
\]
其中\(\text{cost}\)函数表示\(S_{l\cdots r}\)直接被压缩后的长度;若其不能被压缩,则返回\(\infty\)。
子串\((l,r)\)本身就可能被压缩。我们可以考虑从\(1\)至\(\frac{len}{2}\)枚举模式串的长度,如果匹配,则将压缩之后的字符串及其长度作为一个初始决策。之后再枚举合并子区间的价值就可以了。
代码
#include <cstdio>
#include <cstring>
#include <cctype>
using namespace std;
#define rg register
#define openFile(z) freopen(z".in", "r", stdin), freopen(z".out", "w", stdout)
typedef long long ll;
template<class type> inline type quickRead(type sample)
{
type ret = 0, sign = 1; char ch = getchar();
while(! isdigit(ch))
sign = ch == '-' ? -1 : 1, ch = getchar();
while(isdigit(ch))
ret = ret * 10 + ch - '0', ch = getchar();
return sign == -1 ? -ret : ret;
}
const int maxLen = 102;
const int Inf = 0x3f3f3f3f;
struct sub_string
{
char str[maxLen];
int len;
}F[maxLen][maxLen];
char template_string[maxLen];
int Len;
inline void break_point()
{}//用于debug
int main()
{
openFile("POJ2176");
scanf("%s", template_string + 1);
Len = strlen(template_string + 1);
for(rg int i = 1; i <= Len; ++ i)
{
F[i][i].str[0] = template_string[i],
F[i][i].len = 1;
}//初始化,单个字符的最短长度只能是1.
for(rg int len = 2; len <= Len; ++ len)
{
for(rg int l = 1, r = len ; r <= Len; ++ l, ++ r)
{
F[l][r].len = Inf;
for(rg int sub_string_len = 1; sub_string_len <= len >> 1; ++ sub_string_len)
{
//枚举模式串的长度并匹配
if(len % sub_string_len != 0)
continue;//优化:模式串的长度一定是原串的某个约数
int match_left = l, match_right = l + sub_string_len;
while(template_string[match_left] == template_string[match_right] && match_right <= r)
{
++ match_left;
++ match_right;
}
if(match_right > r)//匹配成功
{
sprintf(F[l][r].str, "%d", (r - l + 1) / sub_string_len);
strcat(F[l][r].str, "(");
strcat(F[l][r].str, F[l][l + sub_string_len - 1].str);
strcat(F[l][r].str, ")");
F[l][r].len = strlen(F[l][r].str);//将“压缩自己”作为一个候选决策
break;
}
}
for(rg int k = l; k < r; ++ k)
{
if(F[l][k].len + F[k + 1][r].len < F[l][r].len)//枚举“合并区间”的决策
{
F[l][r].len = F[l][k].len + F[k + 1][r].len;
strcpy(F[l][r].str, F[l][k].str);
strcat(F[l][r].str, F[k + 1][r].str);
}
}
}
}
puts(F[1][Len].str);
return 0;
}
POJ2176 Folding的更多相关文章
- poj2176 Folding【区间DP】
Folding Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1841 Accepted: 642 Special ...
- 常规DP专题练习
POJ2279 Mr. Young's Picture Permutations 题意 Language:Default Mr. Young's Picture Permutations Time L ...
- Codeforces Gym 100002 Problem F "Folding" 区间DP
Problem F "Folding" Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/ ...
- eclipse 插件之Code Folding
功能: eclipse自带折叠包括方法, import, 注释等得折叠功能, code folding 插件对其增强. 1. 下载插件:( 也可以用link方式, 我的是link安装, jar包网上很 ...
- Android Folding View(折叠视图、控件)
版本号:1.0 日期:2014.4.21 版权:© 2014 kince 转载注明出处 非常早之前看过有人求助以下这个效果是怎样实现的, 也就是側滑菜单的一个折叠效果,事实上关于这个效果的实现,谷 ...
- Chrome Dev Tools: Code Folding in CSS and Javascript for improved code readiability
Note : Apply for google chrome canary. You can fold code blocks in CSS (and Sass) and javascript fil ...
- Codeforces Round #397 by Kaspersky Lab and Barcelona Bootcamp (Div. 1 + Div. 2 combined) E. Tree Folding 拓扑排序
E. Tree Folding 题目连接: http://codeforces.com/contest/765/problem/E Description Vanya wants to minimiz ...
- Eclipse折叠代码 coffee bytes code folding
提供一个插件下载地址,博客园的: http://files.cnblogs.com/wucg/com.cb.eclipse.folding_1.0.6.jar.zip 将下载的zip文件解压出来的j ...
- Codeforces Round #397 by Kaspersky Lab and Barcelona Bootcamp (Div. 1 + Div. 2 combined) E. Tree Folding
地址:http://codeforces.com/contest/765/problem/E 题目: E. Tree Folding time limit per test 2 seconds mem ...
随机推荐
- Open-falcon监控
https://book.open-falcon.org/zh_0_2/ 本文档记录了CentOS7.4下open-falcon-v2监控系统的部署流程,以及一些需要注意的地方. 环境准备 安装Red ...
- .Net面试题一
1.进程和线程的区别是什么? 答:https://www.cnblogs.com/renzhuang/articles/6733461.html2.请列举ASP.Net页面之间传递值的几种方式?列出3 ...
- wpf之二进制资源
一.当需要添加图片.音频.视屏的资源到wpf项目里是,可以直接把文件添加到项目里 右击add->existing item. 1.如果想将外部文件编异常目标成为二进制资源,在文件的属性窗口 Bu ...
- input框blur事件 ie问题
在chrome和firefox里会返回 在ie却获取不到relatedTarget:可以通过document.activeElement获取到点击到哪个标签 注意document.activeElem ...
- OSCP-Kioptrix2014-2 漏洞利用
pChart 2.1.3 文件包含漏洞 搜索漏洞 查看漏洞理由代码: hxxp://localhost/examples/index.php?Action=View&Script=%2f..% ...
- Swift调用微信支付宝SDK(Swift4.0)
1.第一步在程序入口注册微信 (支付宝不需要) func application(_ application: UIApplication, didFinishLaunchingWithOption ...
- python之初入Python
python优缺点: Python的优点很多,简单的可以总结为以下几点. 简单和明确,做一件事只有一种方法. 学习曲线低,跟其他很多语言相比,Python更容易上手. 开放源代码,拥有强大的社区和生态 ...
- go语言json转map
package util import ( "encoding/json" "fmt" ) // json转map函数,通用 func JSONToMap(st ...
- Win10系统如何利用蓝牙设置动态锁?
很多小伙伴都会有这样的经历,出门之后没走多远,却已然忘记是否锁门,有强迫症的人就会重新返回查看,以确保门是否反锁. 我们在使用电脑时也是这样,遇到事情要临时离开,却忘记是否锁屏,再返回来就耽误时间了. ...
- pam_smb
What is pam_smb? pam_smb is a PAM module/server which allows authentication of UNIX users using an N ...