数位DP

数位DP

数位dp其实就算是计数dp在某些区间下求满足状态的个数。
做数位dp就是找到并弄清楚题目的约束条件,注意有些题要考虑前导零的情况和确定dp记忆化数组的维度的意义,尽量越多越好,但是不要超出空间,因为维度太少,枚举记忆化的时候,大的数字得到结果可能会把小的数字得到的结果进行覆盖,这样就产生冲突,维度多一点就不会产生这种冲突。上两步分析完之后,再确定空间复杂度,如果超了就找方法降低空间。

int dfs(int pos,int pre,int sta,bool limit)
{
    if(pos==-1) return 1;
    if(!limit && dp[pos][sta]!=-1) return dp[pos][sta];
    int up=limit ? a[pos] : 9;
    int tmp=0;
    for(int i=0;i<=up;i++)
    {
       //在这里判断保证都是保证枚举合法性
        tmp+=dfs(pos-1,i,i==6,limit && i==a[pos]);
    }
    if(!limit) dp[pos][sta]=tmp;
    return tmp;
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值