博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj4230: 倒计时
阅读量:5274 次
发布时间:2019-06-14

本文共 1206 字,大约阅读时间需要 4 分钟。

简直神题啊。。。。我服气 我只会递推的数位DP啊,为啥题解都是dfs的

首先不难想到每次减少一定是变得越小越好,也就是找数位中最大的数减掉

可以这样想,每次把后面一段给压到00.....000x,然后在减去一个数变成999....999y

设f[mx][ln][u]为当前弄到第ln位,前面位的最大值为mx,最后面y等于u。u=10表示就是原数

直接这样转移好了

#include
#include
#include
#include
#include
#include
using namespace std;typedef long long LL;LL mi[20];int a[20];LL f[10][20][11];int res[10][20][11];void dfs(int mx,int ln,int u,LL n){ if(f[mx][ln][u]||res[mx][ln][u])return ; if(ln==1) { if(n==0||mx>n)f[mx][ln][u]=0,res[mx][ln][u]=n; else f[mx][ln][u]=1,res[mx][ln][u]=0; return ; } int tmx,tln=ln-1,tu=u;LL tn=n%mi[ln-1]; for(int i=(u==10)?a[ln]:9;i>=0;i--) { tmx=max(mx,i); dfs(tmx,tln,tu,tn); f[mx][ln][u]+=f[tmx][tln][tu]; tn=i*mi[ln-1]+res[tmx][tln][tu]; if(i!=0) { tu=10+res[tmx][tln][tu]-tmx; tn-=tmx;tn=tn%mi[ln-1]; f[mx][ln][u]++; } else res[mx][ln][u]=res[tmx][tln][tu]; }}int main(){ mi[0]=1;for(int i=1;i<=18;i++)mi[i]=mi[i-1]*10; LL n; scanf("%lld",&n); if(n==0){puts("0");return 0;} LL k=n,ln=0;while(k!=0)a[++ln]=k%10,k/=10; dfs(0,ln,10,n); printf("%lld\n",f[0][ln][10]); return 0;}

 

转载于:https://www.cnblogs.com/AKCqhzdy/p/10435598.html

你可能感兴趣的文章
MVC4.0 利用IActionFilter实现简单的后台操作日志功能
查看>>
rotate the clock
查看>>
bugku 变量
查看>>
Python 环境傻瓜式搭建 :Anaconda概述
查看>>
数据库01 /Mysql初识以及基本命令操作
查看>>
数据库02 /MySQL基础数据类型以及多表之间建立联系
查看>>
Python并发编程04/多线程
查看>>
CF461B Appleman and Tree
查看>>
CF219D Choosing Capital for Treeland
查看>>
杂七杂八的小笔记本
查看>>
51Nod1353 树
查看>>
CF1215E Marbles
查看>>
BZOJ2339 HNOI2011卡农(动态规划+组合数学)
查看>>
octave基本操作
查看>>
axure学习点
查看>>
WPF文本框只允许输入数字[转]
查看>>
dom4j 通用解析器,解析成List<Map<String,Object>>
查看>>
第一个项目--用bootstrap实现美工设计的首页
查看>>
使用XML传递数据
查看>>
TYVJ.1864.[Poetize I]守卫者的挑战(概率DP)
查看>>