poj 1239
二次dp,还算好想。
先第一遍dp找出最后一个数字最小是几。
dpf[i]=max{j}+1(dpf[j],dpf[j]+1,…,j位组成的数字小于j+1,j+2,…,i位组成的数字。
在第二遍dp,找出第一个数字最大是几。
dpb[i]=max{j}(I,i+1,…,j为组成的数字小于j+1,j+2,…,dpb[i+2]位组成的数字。
按轨迹输出。
!记住:每次都要将两个数组清零!(坑了我半天)
代码:
#include<cstdio>
#include<cstring>
using namespace std;
int dpf[90]={0},dpb[90]={0};
char a[90];
int max(int x,int y){
return(x>y)?x:y;
}
int cmp(int x1,int y1,int x2,int y2){
while(a[x1]=='0' && x1<=y1)x1++;
while(a[x2]=='0' && x2<=y2)x2++;
if(x1>y1 && x2>y2)return 1;
if(y1-x1>y2-x2)return 0;
if(y1-x1<y2-x2)return 1;
for(int i=0;i<=y1-x1;i++){
if(a[x2+i]>a[x1+i])return 1;
if(a[x1+i]>a[x2+i])return 0;
}
return 0;
}
int main(){
scanf("%s",a);
while(strlen(a)!=1 || a[0]!='0'){
int l=strlen(a);
dpf[0]=0;
for(int i=1;i<l;i++){
dpf[i]=0;
for(int j=0;j<i;j++)
if(j+1>dpf[i] && cmp(dpf[j],j,j+1,i))
dpf[i]=j+1;
}
// for(int i=0;i<l;i++)printf("%d ",dpf[i]);printf("\n");
int tl=dpf[l-1];
memset(dpb,0,sizeof(dpb));
dpb[tl]=l-1;
for(int i=tl-1;a[i]=='0';i--)
dpb[i]=l-1;
for(int i=tl-1;i>=0;i--){
for(int j=i;j<=tl-1;j++){
if(cmp(i,j,j+1,dpb[j+1]))
dpb[i] = max(dpb[i], j);
}
}
// for(int i=0;i<l;i++)printf("%d ",dpb[i]);printf("\n");
int cur=dpb[0];
for(int i=0;i<l;){
for(;i<=cur && i<l;i++)printf("%c",a[i]);
if(i<l)printf(",");
cur=dpb[cur+1];
}
printf("\n");
scanf("%s",a);
}
return 0;
}
poj 1239的更多相关文章
- POJ 1239 Increasing Sequences 动态规划
题目链接: http://poj.org/problem?id=1239 Increasing Sequences Time Limit: 1000MSMemory Limit: 10000K 问题描 ...
- POJ 1239 Increasing Sequences(经典的两次dp)
http://poj.org/problem?id=1239 题意:给出一串序列,现在要添加逗号作为分隔符,使得序列是递增序列,然后让最后一个数尽量小,第一个数尽量大. 思路:先从头到尾进行一次dp, ...
- POJ 1239 Increasing Sequences [DP]
题意:略. 思路:进行两次dp. 第一次dp从前向后,用dp[x]表示从第x位向前dp[x]位可构成一个数字,且与前面的数组符合题意要求.最后求的dp[n]即为最后一个数字的长度. 而题目还有要求,所 ...
- 【转载】ACM总结——dp专辑
感谢博主—— http://blog.csdn.net/cc_again?viewmode=list ---------- Accagain 2014年5月15日 动态规划一 ...
- 【DP专辑】ACM动态规划总结
转载请注明出处,谢谢. http://blog.csdn.net/cc_again?viewmode=list ---------- Accagain 2014年5月15日 ...
- dp专题训练
****************************************************************************************** 动态规划 专题训练 ...
- 【DP专辑】ACM动态规划总结(转)
http://blog.csdn.net/cc_again/article/details/25866971 动态规划一直是ACM竞赛中的重点,同时又是难点,因为该算法时间效率高,代码量少,多元性强, ...
- dp有哪些种类
dp有哪些种类 一.总结 一句话总结: 二.dp动态规划分类详解 动态规划一直是ACM竞赛中的重点,同时又是难点,因为该算法时间效率高,代码量少,多元性强,主要考察思维能力.建模抽象能力.灵活度. * ...
- (转)dp动态规划分类详解
dp动态规划分类详解 转自:http://blog.csdn.NET/cc_again/article/details/25866971 动态规划一直是ACM竞赛中的重点,同时又是难点,因为该算法时间 ...
随机推荐
- Hibernate内测总结
1.在Hibernate中,以下关于主键生成器说法错误的是( ). A.increment可以用于类型为long.short或byte的主键 B.identity用于如SQL Server.DB2.M ...
- suid sgid sbit chattr lsattr
suid 一般用于二进制可执行文件,suid代表当用户执行此二进制文件时,暂时具有此文件所有者的权限 chmod 4xxx binfile sgid 一般用于目录,sgid代表当其他用户在此目录下创建 ...
- 解决ppt中视频不能播放的问题
小伙伴一直在纠结一个问题,有个ppt,在其他人的电脑上可以正常播放其中的视频,但是在某一个电脑上却总是不能播放,一直没找到原因,俺们今早捯饬了一下,貌似找到一丢丢原因和解决办法了. #1,疑似原因 为 ...
- mybatis 使用经验小结
一.多数据源问题 主要思路是把dataSource.sqlSesstionFactory.MapperScannerConfigurer在配置中区分开,各Mapper对应的包名.类名区分开 <? ...
- 万能的林萧说:一篇文章教会你,如何做到招聘要求中的“要有扎实的Java基础”。
来历 本文来自于一次和群里猿友的交流,具体的情况且听LZ慢慢道来. 一日,LZ在群里发话,"招人啦." 然某群友曰,"群主,俺想去." LZ回之,"你 ...
- MVC模式在UI里的应用
In a similar way to other parts of a game, user interfaces usually go through several iterations unt ...
- add添加
s = {1,2,3,4,5,6,} 进行添加数据! s = {1,2,3,4,5,6,} s.add('s')#添加字符串's' s.add('3')#添加字符串'3' s.add(3)#添加3和字 ...
- C++ URLDecode和URLEncode实现——仅限gb2312,非utf8
转载--http://blog.163.com/zhangjie_0303/blog/static/9908270620148251658993/ #include <iostream> ...
- WCF服务器证书配置说明-没有能够进行密钥交换的私钥,或者进程可能没有访问私钥的权限
WCF服务器证书配置说明 1.创建证书: makecert.exe -sr LocalMachine -ss My -a sha1 -n CN=XXX -sky exchange -pe 说明: -s ...
- STM32库函数编程、Keli/MDK、stm32f103zet6
catalogue . Cortex-M3地址空间 . 基于标准外设库的软件开发 . 基于固件库实现串口输出(发送)程序 . 红外接收实验 . 深入分析流水灯例程 . GPIO再举例之按键实验 . 串 ...