二次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的更多相关文章

  1. POJ 1239 Increasing Sequences 动态规划

    题目链接: http://poj.org/problem?id=1239 Increasing Sequences Time Limit: 1000MSMemory Limit: 10000K 问题描 ...

  2. POJ 1239 Increasing Sequences(经典的两次dp)

    http://poj.org/problem?id=1239 题意:给出一串序列,现在要添加逗号作为分隔符,使得序列是递增序列,然后让最后一个数尽量小,第一个数尽量大. 思路:先从头到尾进行一次dp, ...

  3. POJ 1239 Increasing Sequences [DP]

    题意:略. 思路:进行两次dp. 第一次dp从前向后,用dp[x]表示从第x位向前dp[x]位可构成一个数字,且与前面的数组符合题意要求.最后求的dp[n]即为最后一个数字的长度. 而题目还有要求,所 ...

  4. 【转载】ACM总结——dp专辑

    感谢博主——      http://blog.csdn.net/cc_again?viewmode=list       ----------  Accagain  2014年5月15日 动态规划一 ...

  5. 【DP专辑】ACM动态规划总结

    转载请注明出处,谢谢.   http://blog.csdn.net/cc_again?viewmode=list          ----------  Accagain  2014年5月15日 ...

  6. dp专题训练

    ****************************************************************************************** 动态规划 专题训练 ...

  7. 【DP专辑】ACM动态规划总结(转)

    http://blog.csdn.net/cc_again/article/details/25866971 动态规划一直是ACM竞赛中的重点,同时又是难点,因为该算法时间效率高,代码量少,多元性强, ...

  8. dp有哪些种类

    dp有哪些种类 一.总结 一句话总结: 二.dp动态规划分类详解 动态规划一直是ACM竞赛中的重点,同时又是难点,因为该算法时间效率高,代码量少,多元性强,主要考察思维能力.建模抽象能力.灵活度. * ...

  9. (转)dp动态规划分类详解

    dp动态规划分类详解 转自:http://blog.csdn.NET/cc_again/article/details/25866971 动态规划一直是ACM竞赛中的重点,同时又是难点,因为该算法时间 ...

随机推荐

  1. [tem]线段树练习

    1080 线段树练习 单点修改,区间查询和 #include <iostream> #include <cstdio> #include <algorithm> # ...

  2. 2.bootstrap练习笔记-轮播图

    bootstrap练习笔记-轮播图 1.要使用轮播图,首先要将其放在一个主div里面 设置id为myCaroysel class为carousel slide 设置id是标识这个div是轮播图,等到l ...

  3. vuejs的动态过滤

    想要通过vuejs动态过滤(这里动态指得是过滤的条件是动态变化的), 一直没找到好办法, 最蠢的办法当然是两个两个数组,一个作为原始副本数组 一个作为视图数组,这样当过滤条件变化的时候 动态拷贝原始数 ...

  4. bootstrap 组件

      bootstrap  组件 1下拉菜单(dropdown)  下拉菜单切换(dropdown-toggle)  下拉菜单对齐(dropdown-menu-right-右对齐) 下拉菜单分割线(di ...

  5. 上海闪酷成为京东商城第一批独立软件开发商(ISV)

    闪酷信息技术(上海)有限公司一直致力于为品牌企业提供电子商务软件及其服务,为其拓展电商渠道保驾护航.上海闪酷依据多年的行业经验和技术积累,与中国 最大的B2C商城达成战略合作,为其2万多家品牌供应商提 ...

  6. PHP引用(&)使用详解

    初学php关于&引用 官方文档: 1.引用是什么:http://www.php.net/manual/zh/language.references.whatare.php 2.引用做什么:ht ...

  7. 使用Cordova和JQM在ios上需要注意的问题

    1.ios编译 cordova platform add ios --save cordova build ios 2.IOS 微信和地图調用問題:因IOS 9.0以上版本白名單限制,衹有加入白名單的 ...

  8. Computer vision labs

    积累记录一些视觉实验室,方便查找 1.  多伦多大学计算机科学系 2.  普林斯顿大学计算机视觉和机器人实验室 3.  牛津大学Torr Vision Group 4.  伯克利视觉和学习中心 Pro ...

  9. 微信支付开发(1) JS API支付

    关键字:微信支付 微信支付v3 jsapi支付 统一支付 Native支付 prepay_id 作者:方倍工作室原文: http://www.cnblogs.com/txw1958/p/wxpayv3 ...

  10. 我是服务的执政官-服务发现和注册工具consul简介

    服务发现和注册 我们有了两个服务.服务A的IP地址是192.168.0.1,端口9001,服务B的IP地址192.168.0.2,端口9002.我们的客户端需要调用服务A和服务B,我们只需要在配置文件 ...