数位dp--HYSBZ1026 windy数

windy数,相邻数字相差大于等于2.

#include <iostream>

#include <cstring>

#include <cmath>

using namespacestd;

int bits[12];

int dp[12][10][2];


int dfs(int len,int pre,bool lead,bool border)//len个数,前一个数为pre,是否有前导0,是否在边界

{

    if(!len)return 1;

    if(!border &&dp[len][pre][lead] != -1 )return dp[len][pre][lead];

    int res =0,up = border ? bits[len] :9;

    for (int i =0; i <= up; i ++) {

        if(lead || ((i - pre >=2) || (i - pre) <= -2))

          res +=  dfs(len -1, i,lead && (i == 0), border && (i == up));

    }

    if(!border)dp[len][pre][lead] = res;

    return res;

}

int f(int x)

{

    int len =0;

    while (x) {

        bits[++len] = x %10;//数位从1存到n

        x /= 10;

    }

    returndfs(len,0,1,1);//一开始是有前导0的

}

int main()

{

    memset(dp, -1,sizeof(dp));

   int a,b;

    cin >> a >> b;

    cout <<f(b) - f(a -1) << endl;

    return0;

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值