题意:

给你一串数字,要求你对其进行折叠使其长度最短。
折叠情况:全是一个字母 & 重复的字符串

AAAAAAAAAABABABCCD    -->   9(A)3(AB)CCD
NEERCYESYESYESNEERCYESYESYES      -->       2(NEERC3(YES))

思路:

用dp[i][j]表示从 i 到 j 的最短情况。 不停的往下找,得到 i 到 j 的字符串后,再判断能否折叠
大致思路如此,中间WR了一把,在将长度转换成字符型时直接用的 t + ‘0’,WR后发现大于9就木有了- -,这智商
强行坑自己一波。

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std;
const int maxn = 105;
int dp[maxn][maxn];
string ans[105][105];
string s; int judge(int l,int r) //判断折叠
{
int i,j;
bool flag =true;
for(i = 1; i <= (r-l+1)/2; i++)
{
if((r-l+1) % i) continue;
flag = true;
for(j = l; j+i <= r; j++)
{
if(s[j] != s[j+i])
{
flag = false;
break;
}
}
if(flag)
return i;
}
return false;
} int dfs(int l,int r)
{
if(dp[l][r] != -1)
return dp[l][r];
if(l == r)
{
dp[l][r] = 1;
ans[l][r] = s[l];
return 1;
} int tt = 0x3f3f3f3f;
int k;
for(int i = l; i < r; i++) //找出最短
{
int tmp = dfs(l,i) + dfs(i+1,r); //左右两段合并
if(tt > tmp)
{
k = i;
tt = tmp;
}
}
// cout << l <<" " << r << endl;
ans[l][r] = ans[l][k] + ans[k+1][r]; //得到临时最短NEERC3(YES)NEERC3(YES)
tt = dp[l][k] + dp[k+1][r]; int flag = judge(l,r); //再次判断能否折叠,例:NEERC3(YES)NEERC3(YES) -> 2(NEERC3(YES))
if(flag)
{
char orz[5];
int t = (r-l+1)/flag;
sprintf(orz,"%d",t);
string tans = string(orz)+"("+ans[l][l+flag-1]+")";
if(tans.size() < tt)
{
tt = tans.size();
ans[l][r] = tans;
}
}
// cout <<ans[l][r] <<" " << l << " " << r << endl;
return dp[l][r] = tt;
} int main()
{
while(cin >> s)
{
int len = s.size()-1;
memset(dp,-1,sizeof(dp));
dfs(0,len);
cout<<ans[0][len]<<endl;
}
return 0;
}

  

习题9-4 uva 1630的更多相关文章

  1. Uva 1630 折叠串

    题目链接:https://uva.onlinejudge.org/external/16/1630.pdf 题意:折叠串,给一个字符串,相同部分可以折叠,折叠可以嵌套.求最短长度的一种折叠方法.括号和 ...

  2. UVa 1630 Folding (区间DP)

    题意:折叠一个字符串,使得其成为一个尽量短的字符串  例如AAAAAA变成6(A) 而且这个折叠是可以嵌套的,例如 NEEEEERYESYESYESNEEEEERYESYESYES 会变成 2(N5( ...

  3. UVa 1630 串折叠

    https://vjudge.net/problem/UVA-1630 题意: 给出一个由大写字母组成的长度为n的串,折叠成一个尽量短的串.例如:AAAAAAAAABABABCCD折叠成9(A)3(A ...

  4. UVa 1630 区间DP Folding

    一个字符串如果能简写,要么是重复多次,按题中的要求简写:要么是左右两个部分分别简写后再拼起来. dp(i, j)表示字串(i, j)所能被简写的最短的字符串. 判断一个字符串是否为周期串以及求出它的周 ...

  5. Folding UVA - 1630

    题目 ans[i][j]表示由原串第i个字符到第j个字符组成的子串的最短折叠长度如果从i到j本身可以折叠,长度就是本身长度或折叠后的长度的最小值***此处参考:http://blog.csdn.net ...

  6. 【Uva 1630】Folding

    [Link]: [Description] 你能对字符串进行压缩的操作; 即把连续出现的相同的子串改成它出现的次数+这个最基本的字符串的形式; 问你这个字符串最短能被压缩得多短; [Solution] ...

  7. UVA - 1630 Folding(串折叠)(dp---记忆化搜索)

    题意:给出一个由大写字母组成的长度为n(1<=n<=100)的串,“折叠”成一个尽量短的串.折叠可以嵌套.多解时可输出任意解. 分析: 1.dp[l][r]为l~r区间可折叠成的最短串的长 ...

  8. ACM训练计划建议(写给本校acmer,欢迎围观和指正)

    ACM训练计划建议 From:freecode#  Date:2015/5/20 前言: 老师要我们整理一份训练计划给下一届的学弟学妹们,整理出来了,费了不少笔墨,就也将它放到博客园上供大家参考. 菜 ...

  9. ACM训练计划建议(转)

    ACM训练计划建议 From:freecode#  Date:2015/5/20 前言: 老师要我们整理一份训练计划给下一届的学弟学妹们,整理出来了,费了不少笔墨,就也将它放到博客园上供大家参考. 菜 ...

随机推荐

  1. GPUImage实战问题解决

    在项目中遇到了使用完GPUImage以后,内存不释放的问题,翻阅官方API,找到了解决方法: deinit{ GPUImageContext.sharedImageProcessingContext( ...

  2. (原创)不带模板的OLE输出EXCEL

    目前我已知的EXCEL输出方式有3种: 1.GUI_DOWNLOAD函数输出(适用于简单无格式要求的输出). 2.OLE输出(适用于对EXCEL格式输出有特殊要求的,但是因其填充数据和设置格式是基于一 ...

  3. 最短路算法模板SPFA、disjkstra、Floyd

    朴素SPFA(链表建边) #include <iostream> #include <cstdio> #include <cstring> #include < ...

  4. ASCII排序

    ASCII码排序 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 输入三个字符(可以重复)后,按各字符的ASCII码从小到大的顺序输出这三个字符.   输入 第一行输 ...

  5. 18-TypeScript模板方法模式

    在有些情况下,一个功能在基础功能上是不会变的,算法的基本骨架也是确定的,但是在某些场景下算法的具体实现有些差异.应对这种问题,可以采用模板方法模式: abstract class Salary{ ab ...

  6. HTTP头HOST

    http request header 中的host行的作用 在早期的Http 1.0版中,Http 的request请求头中是不带host行的,在Http 1.0的加强版和Http 1.1中加入了h ...

  7. 英语词汇周计划(1-1)group 1

    abandon 1.He abandoned his wife and ten-year-old daughter. 2.abandon oneself to do sth 3.with abando ...

  8. Mysql官方文档翻译系列14.18--MySql备份与恢复

    原文链接: (https://dev.mysql.com/doc/refman/5.7/en/innodb-backup-recovery.html) The key to safe database ...

  9. 对于错误“Refused to execute script from '...' because its MIME type ('') is not executable, and strict MIME type checking is enabled.”的处理。

    今天在是用公司的报表插件Stimulsoft时发现的问题.之前可以正常使用,突然不能加载了.查看发现得到这个错误. 查看请求头 可以看到,请求正常响应,但是发现 Content-Type是空的,但是引 ...

  10. Mysql 库表

    create database student_info default character set utf8 collate utf8_general_ci; ------------------- ...