习题9-4 uva 1630
题意:
给你一串数字,要求你对其进行折叠使其长度最短。
折叠情况:全是一个字母 & 重复的字符串
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的更多相关文章
- Uva 1630 折叠串
题目链接:https://uva.onlinejudge.org/external/16/1630.pdf 题意:折叠串,给一个字符串,相同部分可以折叠,折叠可以嵌套.求最短长度的一种折叠方法.括号和 ...
- UVa 1630 Folding (区间DP)
题意:折叠一个字符串,使得其成为一个尽量短的字符串 例如AAAAAA变成6(A) 而且这个折叠是可以嵌套的,例如 NEEEEERYESYESYESNEEEEERYESYESYES 会变成 2(N5( ...
- UVa 1630 串折叠
https://vjudge.net/problem/UVA-1630 题意: 给出一个由大写字母组成的长度为n的串,折叠成一个尽量短的串.例如:AAAAAAAAABABABCCD折叠成9(A)3(A ...
- UVa 1630 区间DP Folding
一个字符串如果能简写,要么是重复多次,按题中的要求简写:要么是左右两个部分分别简写后再拼起来. dp(i, j)表示字串(i, j)所能被简写的最短的字符串. 判断一个字符串是否为周期串以及求出它的周 ...
- Folding UVA - 1630
题目 ans[i][j]表示由原串第i个字符到第j个字符组成的子串的最短折叠长度如果从i到j本身可以折叠,长度就是本身长度或折叠后的长度的最小值***此处参考:http://blog.csdn.net ...
- 【Uva 1630】Folding
[Link]: [Description] 你能对字符串进行压缩的操作; 即把连续出现的相同的子串改成它出现的次数+这个最基本的字符串的形式; 问你这个字符串最短能被压缩得多短; [Solution] ...
- UVA - 1630 Folding(串折叠)(dp---记忆化搜索)
题意:给出一个由大写字母组成的长度为n(1<=n<=100)的串,“折叠”成一个尽量短的串.折叠可以嵌套.多解时可输出任意解. 分析: 1.dp[l][r]为l~r区间可折叠成的最短串的长 ...
- ACM训练计划建议(写给本校acmer,欢迎围观和指正)
ACM训练计划建议 From:freecode# Date:2015/5/20 前言: 老师要我们整理一份训练计划给下一届的学弟学妹们,整理出来了,费了不少笔墨,就也将它放到博客园上供大家参考. 菜 ...
- ACM训练计划建议(转)
ACM训练计划建议 From:freecode# Date:2015/5/20 前言: 老师要我们整理一份训练计划给下一届的学弟学妹们,整理出来了,费了不少笔墨,就也将它放到博客园上供大家参考. 菜 ...
随机推荐
- Flask 蓝图(Blueprint)
蓝图使用起来就像应用当中的子应用一样,可以有自己的模板,静态目录,有自己的视图函数和URL规则,蓝图之间互相不影响.但是它们又属于应用中,可以共享应用的配置.对于大型应用来说,我们可以通过添加蓝图来扩 ...
- JAVA和Android的回调机制
本文出自xiaanming的博客(http://blog.csdn.net/xiaanming/article/details/17483273),请尊重他人的辛勤劳动成果,谢谢 以 前不理解什么叫回 ...
- Mego(06) - 关系数据库建模
框架中提供了多种数据注释以便可以全面的描述数据库结构特性. 自增列 可以使用注释声明指定列是数据库自增列,同时能指定自增的起始及步长. public class Blog { [Identity(, ...
- Python内置函数(26)——enumerate
英文文档: enumerate(iterable, start=0) Return an enumerate object. iterable must be a sequence, an itera ...
- 新概念英语(1-37)Making a bookcase
What is Susan's favourite color ? A:You're working hard, Georage. What are you doing? B:I am making ...
- Python学习之参数
参数 # coding=utf-8 # 函数的参数 def power(x): return x * x; print power(5) 修改后 def power_1(x,n=2): #默认参数可以 ...
- Dapper中条件为In的写法
今天用Dapper更新是用到了IN写法,园子里找了篇文章这样写到 传统sql in (1,2,3) 用dapper就这样写 conn.Query<Users>("SELECT * ...
- Python/Django(CBV/FBV/ORM操作)
Python/Django(CBV/FBV/ORM操作) CBV:url对应的类(模式) ##====================================CBV操作============ ...
- 云服务器ECS优惠券 阿里云 ecs 5折优惠码 阿里云5折优惠码 阿里云5折推荐码 阿里云优惠码 阿里云的5折优惠券 阿里云服务器购买优惠码 服务器购买优惠码
阿里云代金券 | 阿里云优惠券云服务器ECS,就是阿里云服务器,大家一定要清楚.云服务器ECS优惠券官方领取优惠页面:https://promotion.aliyun.com/ntms/act/amb ...
- 合并css 合并图片 合并js
1:合并css 如:index.html 中的代码 <!DOCTYPE html><html lang="en"><head> <me ...