POJ2033 动态规划

原创 2016年08月31日 08:42:05

一共三种状态:

1。当前数是0的话,只能和之前的数组合,dp[i]=dp[i-2]; 例如11110: 111   10

2。当前不为0,之前的数不为0并且组合产生的字母不超出范围(11-26),说明这个数既可以和之前组合,也可以不组合,dp[i]=dp[i-2]+dp[i-1]  例如1111有两种分割:

11    11  ,111   1

3。当前数不为0,但之前的数为0,之前的数不能和当前数组合,dp[i]=dp[i-1]; 例如:11101:1110   1


dp[0],dp[1]是边界。


十分感谢你的代码和注释。

#include"stdio.h"
#include"iostream"
#include"algorithm"
#include"string"
using namespace std;
typedef long long ll;
const int maxn=50001;
ll dp[maxn];
int main()
{
    string a;
    while(cin>>a)
    {
        if(a[0]=='0')break;
        dp[0]=1;int len=a.size();
        for(int i=1;i<len;i++)
        {
            int num1=a[i]-48;int num2=a[i-1]-48;int num=num1+num2*10;
            if(num1==0)
            {
                if(i==1) dp[i]=1;
                else dp[i]=dp[i-2];
            }
            else
            {
                if(num>=11&&num<=26)
                {
                    if(i==1) dp[i]=2;
                    else dp[i]=dp[i-1]+dp[i-2];
                }
                else
                    dp[i]=dp[i-1];
            }
        }
        cout<<dp[len-1]<<endl;
    }

}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

POJ 2033 DP

很快就想出方法的一道DP,但却忽略了一些特殊情况,以后要考虑周全,能够想到tricks...

poj2033 dp

a对应1,b对应2……z对应26,给一串数,问译成字母有多少种不同的情况?要注意0的问题!有些丑陋了……#include #include using namespace std; int ...
  • lencle
  • lencle
  • 2011年03月02日 20:01
  • 639

POJ 2033 Alphacode 笔记

字符被编码成数字。A被编码成1,B被编码成2,以此类推。求给出的数字能翻译成多少种字符串。...

poj经典动态规划题目解题报告

  • 2008年03月23日 19:09
  • 539KB
  • 下载

POJ1163 The Triangle(数字三角形) (动态规划初步)

 Description 7 3 8 8 1 0 2 7 4 4 4 5 2 6 5 (Figure 1) Figure 1...

poj1837 动态规划和01背包问题延伸的经典题目,很值得一做

首先说一下基本思路,是按照小优博客上来的思路,即平衡度来做的,其博主在博客上写得已经非常全面了,这里转载一下: 来源:http://blog.csdn.net/lyy289065406/articl...

POJ 2479 动态规划 最大子序列问题(两段) Maximum sum

做ACM练习题目已经两个年头了,最开始脑子很混乱,后来慢慢有了感觉,AC率也大幅度提高,接下来就一些经典问题做一下回顾,这些问题涵盖了算法的多个方面,相对来说有一些较为全面的总结,也是我这些年劳动成果...

经典动态规划问题--最长上升子序列 POJ--2533

经典动态规划问题--最长上升子序列 POJ--2533

POJ - 1042 Gone Fishing 钓鱼 动态规划(DP)

【问题描述】 约翰是个垂钓谜,星期天他决定外出钓鱼h小时(1≤h≤16),约翰家附近共有n个池塘(2≤n≤25),这些池塘分布在一条直线上,约翰将这些池塘按离家的距离由近到远编上号,依次为L1,L2...

动态规划 POJ 2184 Cow Exhibition

原题链接:poj 2184 原题
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:POJ2033 动态规划
举报原因:
原因补充:

(最多只允许输入30个字)