Link:

BZOJ 1799 传送门

Solution:

一句话的题目,看得爽,做得烦

一般这类和数位相关的都是数位$dp$吧

不过一开始还是感觉不太可做,毕竟每个数模数不同

但要发现,模数最高也只可能为$9*19=171$,

于是只要将数按照他们的数位和(即模数)分类计算即可

这样便暴力解决了模数不同的问题

设$dp[sp][sum][rmd][lmt]$表示:

枚举到第$sp$高位,剩下的数的和位$sum$,此时对$mod$余$rmd$时的方案数(lmt表示是否达到上界)

感觉数位$dp$还是用记忆化搜索写起来逻辑比较清晰吧

Code:

  1. #include <bits/stdc++.h>
  2.  
  3. using namespace std;
  4. typedef long long ll;
  5. const int MAXN=; //n可能为19,sum最大为171
  6. int vis[][MAXN][MAXN][],mod,dgt,cur,num[];
  7. ll a,b,dp[][MAXN][MAXN][];
  8.  
  9. ll dfs(int sp,int sum,int rmd,int lmt)
  10. {
  11. if(!sp) return !sum && !rmd;
  12. if(vis[sp][sum][rmd][lmt]==cur) return dp[sp][sum][rmd][lmt];
  13. vis[sp][sum][rmd][lmt]=cur;ll ret=;
  14.  
  15. int l=max(,sum-(sp-)*),r=min((lmt)?num[sp]:,sum);
  16. for(int i=l;i<=r;i++)
  17. ret+=dfs(sp-,sum-i,(rmd*+i)%mod,lmt&(i==num[sp]));
  18. return dp[sp][sum][rmd][lmt]=ret;
  19. }
  20.  
  21. ll solve(ll x)
  22. {
  23. ll ret=;
  24. for(dgt=;x;x/=) num[++dgt]=x%;
  25. for(mod=;mod<=dgt*;mod++)
  26. cur++,ret+=dfs(dgt,mod,,);
  27. return ret;
  28. }
  29.  
  30. int main()
  31. {
  32. scanf("%lld%lld",&a,&b);
  33. printf("%lld\n",solve(b)-solve(a-));
  34. return ;
  35. }

Review:

1、少用$memset$,尽量在使用时顺便初始化

为了区分不同次的调用,可以在每一次调用打上不同的标记

2、在$dp$时难以处理模数不同的情况

考虑将数据分类后直接暴力所有可能的模数

3、$1e18$可能有19位,$MAXN$要设为175

(一开始扫了一眼题解上$MAXN$为165,以后还是要自己算啊……)

[BZOJ 1799] self 同类分布的更多相关文章

  1. HYSBZ - 1799 self 同类分布

    self 同类分布 HYSBZ - 1799 给出a,b,求出[a,b]中各位数字之和能整除原数的数的个数.Sample Input 10 19 Sample Output 3 Hint [约束条件] ...

  2. bzoj 1799: [Ahoi2009]self 同类分布 数位dp

    1799: [Ahoi2009]self 同类分布 Time Limit: 50 Sec  Memory Limit: 64 MB[Submit][Status][Discuss] Descripti ...

  3. bzoj 1799: [Ahoi2009]self 类似的分布 解读

    [原标题] 1799: [Ahoi2009]self 同类分布 Time Limit: 50 Sec  Memory Limit: 64 MB Submit: 554  Solved: 194 [id ...

  4. 【BZOJ1799】[AHOI2009]同类分布(动态规划)

    [BZOJ1799][AHOI2009]同类分布(动态规划) 题面 BZOJ 洛谷 题解 很容易想到数位\(dp\),然而数字和整除原数似乎不好记录.没关系,直接枚举数字和就好了,这样子就可以把整除原 ...

  5. [BZOJ1799][AHOI2009]同类分布(数位DP)

    1799: [Ahoi2009]self 同类分布 Time Limit: 50 Sec  Memory Limit: 64 MBSubmit: 1635  Solved: 728[Submit][S ...

  6. [Ahoi2009]self 同类分布

    1799: [Ahoi2009]self 同类分布 Time Limit: 50 Sec  Memory Limit: 64 MBSubmit: 2357  Solved: 1079[Submit][ ...

  7. BZOJ1799 self 同类分布 数位dp

    BZOJ1799self 同类分布 去博客园看该题解 题意 给出a,b,求出[a,b]中各位数字之和能整除原数的数的个数. [约束条件]1 ≤ a ≤ b ≤ 10^18 题解 1.所有的位数之和&l ...

  8. 洛谷 P4127 [AHOI2009]同类分布 解题报告

    P4127 [AHOI2009]同类分布 题目描述 给出两个数\(a,b\),求出\([a,b]\)中各位数字之和能整除原数的数的个数. 说明 对于所有的数据,\(1 ≤ a ≤ b ≤ 10^{18 ...

  9. P4127 [AHOI2009]同类分布

    P4127 [AHOI2009]同类分布 题解 好的,敲上数位DP  DFS板子 记录一下填的各位数字之和 sum ,然后记录一下原数 yuan 最后判断一下  yuan%sum==0 不就好啦??? ...

随机推荐

  1. Website Collection

    前一百个卡特兰数 Candy?的博弈论总结 杜教筛资料 线性基资料 (ex)BSGS资料 斐波那契数列前300项 斯特林数 STL标准库-容器-unordered_set C++ unordered_ ...

  2. 一个JavaScript反射使用的例子

    反射机制指的是程序在运行时能够获取自身的信息.例如一个对象能够在运行时知道自己有哪些方法和属性.在JavaScript中有一个很方便的语法来实现反射,即for(…in…)语句,其语法如下: 1 for ...

  3. [SDOI2016] 排列计数 (组合数学)

    [SDOI2016]排列计数 题目描述 求有多少种长度为 n 的序列 A,满足以下条件: 1 ~ n 这 n 个数在序列中各出现了一次 若第 i 个数 A[i] 的值为 i,则称 i 是稳定的.序列恰 ...

  4. Java多线程-一个简单的线程,实现挂起和恢复的功能

    public class MySprite implements Runnable { /* * 线程用变量 */ private boolean running = false; private b ...

  5. Java基础学习知识体系图

  6. Nim博弈(nim游戏)

    http://blog.csdn.net/qiankun1993/article/details/6765688 NIM 游戏 重点结论:对于一个Nim游戏的局面(a1,a2,...,an),它是P- ...

  7. Ubuntu下hadoop集群搭建

    --修改IP地址(克隆镜像后可修改可不修改) http://jingyan.baidu.com/article/e5c39bf5bbe0e739d7603396.html -------------- ...

  8. IDEA无法编译java8的lambda表达式提示Error:(16, 48) java: -source 1.5 中不支持 lambda 表达式

    在idea中新建了一个java8的项目,但是写lambda表达式提示语法错误,提示如下错误信息: Error:(16, 48) java: -source 1.5 中不支持 lambda 表达式 (请 ...

  9. Eclipse Tomcat部署项目没有加载新加的静态资源文件

    额,一直用MyEclipse,后来用Eclipse时,启动项目后去Tomcat webapps找对应文件夹,发现没有,才知道Eclipse 默认不往本地Tomcat部署. 1.eclipse不像MyE ...

  10. Pycharm中快捷键大全

    #1.按住ctrl然后鼠标放在函数上就会提示出这个函数有那些参数,双击进入该函数. 1.Pycharm中快捷键大全,遇到一个更新一个 撤销与反撤销:Ctrl + z,Ctrl + Shift + z ...