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竞赛中的重点,同时又是难点,因为该算法时间 ...
随机推荐
- JSP九大内置组件
request:用户端请求,此请求会包含来自get/post请求的参数 response:网页传回用户端的回应 pagecontext:网页上下文,也就是网页的属性 session:与请求有关的会话期 ...
- NPM 无法下载任何包的原因,解决方法
前几天发现NPM 无法现在任何的包 通过npm i testPackage -ddd 发现 是卡在了 npm verb addRemoteTarball 这行,google后发现 是有多个tmp地址, ...
- JavaScript从数组中删除指定值元素的方法
本文实例讲述了JavaScript从数组中删除指定值元素的方法.分享给大家供大家参考.具体分析如下: 下面的代码使用了两种方式删除数组的元素,第一种定义一个单独的函数,第二种为Array对象定义了一个 ...
- title与alt的区别
html中的title属性和alt属性让人有些混淆. 以前不知道有title这个属性,第一次用到它时,就和alt产生了混淆.一位朋友告诉我说,alt是图片img标签里用的,title是超链接里用的, ...
- C#进阶系列——MEF实现设计上的“松耦合”(二)
前言:前篇 C#进阶系列——MEF实现设计上的“松耦合”(一) 介绍了下MEF的基础用法,让我们对MEF有了一个抽象的认识.当然MEF的用法可能不限于此,比如MEF的目录服务.目录筛选.重组部件等高级 ...
- EF6 在 SQLite中使用备忘
== 菜鸟级选手试验在EF6中使用Sqlite,零EF基础,少量Sqlite基础.经过断断续续的很长时间 - _ -! >>连接 1. 安装 使用目前最新版本EF6.1,Sqlite1.0 ...
- 解决 PHPExcel 长数字串显示为科学计数
解决 PHPExcel 长数字串显示为科学计数 在excel中如果在一个默认的格中输入或复制超长数字字符串,它会显示为科学计算法,例如身份证号码,解决方法是把表格设置文本格式或在输入前加一个单引号. ...
- c#编码转换
/// <summary> /// URL编码 /// </summary> /// <param name="Source"></par ...
- Html页面禁止鼠标左键复制
<body leftmargin=0 topmargin=0 oncontextmenu='return false' ondragstart='return false' onselectst ...
- ASP.NET MVC中viewData、viewBag和templateData的使用与区别
一:类型比较 1.1)ViewBag是动态类型(dynamic). 1.2)ViewData是一个字典型的(Dictionary)-->ViewDataDictionary. 1.3)TempD ...