D. Beautiful numbers
time limit per test

4 seconds

memory limit per test

256 megabytes

input

standard input

output

standard output

Volodya is an odd boy and his taste is strange as well. It seems to him that a positive integer number is beautiful if and only if it is divisible by each of its nonzero digits. We will not argue with this and just count the quantity of beautiful numbers in given ranges.

Input

The first line of the input contains the number of cases t (1≤t≤10). Each of the next t lines contains two natural numbers li and ri (1≤liri≤9·1018).

Please, do not use %lld specificator to read or write 64-bit integers in C++. It is preffered to use cin (also you may use %I64d).

Output

Output should contain t numbers — answers to the queries, one number per line — quantities of beautiful numbers in given intervals (from li to ri, inclusively).

Sample test(s)
input

1
1 9

output

9

input

1
12 15

output

2

  1. /*
  2. a positive integer number is beautiful if and only if it is divisible by each of its nonzero digits.
  3. 问一个区间内[l,r]有多少个Beautiful数字
  4. 范围9*10^18
  5. 数位统计问题,构造状态也挺难的,我想不出,我的思维局限在用递推去初始化状态,而这里的状态定义也比较难
  6. 跟pre的具体数字有关
  7. 问了NotOnlySuccess的,豁然开朗  Orz
  8. 一个数字要被它的所有非零位整除,即被他们的LCM整除,可以存已有数字的Mask,但更好的方法是存它们的LCM{digit}
  9. int MOD = LCM{1,2,9} = 5 * 7 * 8 * 9 = 2520
  10. 按照定义,数字x为Beautiful :
  11. x % LCM{digit[xi]} = 0
  12. 即 x % MOD % LCM{digit[xi]} = 0
  13. 所以可以只需存x % MOD,范围缩小了
  14. 而在逐位统计时,假设到了pre***(pre指前面的一段已知的数字,而*是任意变)
  15. ( preSum * 10^pos + next )  % MOD % LCM(preLcm , nextLcm)
  16. =  ( preSum * 10 ^ pos % MOD + next % MOD ) % LCM(preLcm , nextLcm)
  17. == 0
  18. 而next,nextLcm是变量,上面的比较式的意义就是
  19. 在已知pos , preSum , preLcm情况下有多少种(next,nextLcm)满足式子为0
  20. 而这个就是一个重复子问题所在的地方了,需要记录下来,用记忆化搜索
  21. dfs(pos , preSum , preLcm , doing)
  22. 加一个标记为doing表示目前是在计算给定数字的上限,还是没有上限,即***类型的
  23. 这样就将初始化以及逐位统计写在一个dfs了,好神奇!!!
  24. 还有一点,10以内的数字情况为2^3 , 3^2 , 5 , 7
  25. 所以最小公倍数组合的情况只有4*3*2*2 = 48
  26. 可以存起来,我看NotOnlySuccess的写法是
  27. for(int i = 1 ; i <= MOD ; i ++)
  28. {
  29. if(MOD % i == 0)
  30. index = num++;
  31. }
  32. 很棒!!
  33. 所以复杂度大概为19*2520*48*10(状态数*决策数)
  34. 我觉得这题状态的设计不能跟具体数字分开,否则会很难设计吧
  35. 所以用记忆化搜索,存起来
  36. 用具体数字去计算,重复的子问题跟pre关系比较密切
  37. 有一个比较重要的切入点就是LCM,还有%MOD缩小范围,才能存储
  38. 还有优化到只需%252的,更快
  39. 不过我觉得%2520比较好理解
  40. */
#include <iostream>
#include <cstdio>
#include <cstring>

using namespace std;

typedef long long int LL;

const int MOD=2520;

LL Gcd(LL a,LL b)
{
    return (a==0)?b:Gcd(b%a,a);
}

LL Lcm(LL a,LL b)
{
    if(a>b) swap(a,b);
    return a/Gcd(a,b)*b;
}

LL dp[20][MOD+10][50],lcm[MOD+10],bit[20];

void Init()
{
    int num=0;
    for(int i=1;i<=MOD;i++)
    {
        if(MOD%i==0)
            lcm=num++;
    }
    memset(dp,-1,sizeof(dp));
}

LL dfs(int pos,int presum,int preLcm,bool limit)
{
    if(pos==-1)
        return presum%preLcm==0;
    if(!limit&&~dp[pos][presum][lcm[preLcm]]) return dp[pos][presum][lcm[preLcm]];
    int end=limit?bit[pos]:9;
    LL ans=0;
    for(int i=0;i<=end;i++)
    {
        int newsum=(presum*10+i)%MOD;
        int newLcm=preLcm;
        if(i)
        {
            newLcm=Lcm(preLcm,i);
        }
        ans+=dfs(pos-1,newsum,newLcm,limit&&i==end);
    }
    if(!limit)
        dp[pos][presum][lcm[preLcm]]=ans;
    return ans;
}

LL calu(LL x)
{
    int pos=0;
    while(x)
    {
        bit[pos++]=x%(10LL);
        x/=(10LL);
    }
    return dfs(pos-1,0,1,true);
}

int main()
{
    int t;
    scanf("%d",&t);
    Init();
    while(t--)
    {
        LL a,b;
        scanf("%I64d%I64d",&a,&b);
        printf("%I64d\n",calu(b)-calu(a-1));
    }
    return 0;
}

* This source code was highlighted by YcdoiT. ( style: Codeblocks )

CodeForces 55D Beautiful numbers的更多相关文章

  1. CodeForces 55D "Beautiful numbers"(数位DP+离散化处理)

    传送门 参考资料: [1]:CodeForces 55D Beautiful numbers(数位dp&&离散化) 我的理解: 起初,我先定义一个三维数组 dp[ i ][ j ][ ...

  2. Codeforces 55D. Beautiful numbers(数位DP,离散化)

    Codeforces 55D. Beautiful numbers 题意 求[L,R]区间内有多少个数满足:该数能被其每一位数字都整除(如12,24,15等). 思路 一开始以为是数位DP的水题,觉得 ...

  3. codeforces 55D - Beautiful numbers(数位DP+离散化)

    D. Beautiful numbers time limit per test 4 seconds memory limit per test 256 megabytes input standar ...

  4. CodeForces - 55D Beautiful numbers —— 数位DP

    题目链接:https://vjudge.net/problem/CodeForces-55D D. Beautiful numbers time limit per test 4 seconds me ...

  5. CodeForces - 55D - Beautiful numbers(数位DP,离散化)

    链接: https://vjudge.net/problem/CodeForces-55D 题意: Volodya is an odd boy and his taste is strange as ...

  6. CodeForces 55D Beautiful numbers (SPOJ JZPEXT 数位DP)

    题意 求[X,Y]区间内能被其各位数(除0)均整除的数的个数. CF 55D 有些时候因为问题的一些"整体性"而导致在按位统计的过程中不能顺便计算出某些量,所以只能在枚举到最后一位 ...

  7. CodeForces 55D Beautiful numbers(数位dp+数学)

    题目链接:http://codeforces.com/problemset/problem/55/D 题意:一个美丽数就是可以被它的每一位的数字整除的数. 给定一个区间,求美丽数的个数. 显然这是一道 ...

  8. CodeForces 55D Beautiful numbers(数位dp)

    数位dp,三个状态,dp[i][j][k],i状态表示位数,j状态表示各个位上数的最小公倍数,k状态表示余数 其中j共有48种状态,最大的是2520,所以状态k最多有2520个状态. #include ...

  9. codeforces 55D. Beautiful numbers 数位dp

    题目链接 一个数, 他的所有位上的数都可以被这个数整除, 求出范围内满足条件的数的个数. dp[i][j][k], i表示第i位, j表示前几位的lcm是几, k表示这个数mod2520, 2520是 ...

随机推荐

  1. <base href="<%=basePath%>

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ...

  2. [Eclipse]解决: Eclipse Maven “Add Dependency”搜索无结果

    转载: http://www.educity.cn/wenda/469389.html eclipse插件Maven添加依赖查询无结果的解决方法(Select Dependency doesn't w ...

  3. Mouse.OverrideCursor

    介绍: 获取和设置整个应用程序的光标,WPF父元素将覆盖所有子元素的光标. WPF设置控件的光标: WPF 中每个光标通过一个System.Windows.Input.Cursor表示, 获取Curs ...

  4. POJ - 1511 Invitation Cards(Dijkstra变形题)

    题意: 给定一个有向图,求从源点到其他各点的往返最短路径和.且这个图有一个性质:任何一个环都会经过源点. 图中的节点个数范围:0-100w; 分析: 我们先可以利用Dijkstra算法求解从源点到其余 ...

  5. HD1599 find the mincost route(floyd + 最小环)

    题目链接 题意:求最小环 第一反应时floyd判断,但是涉及到最少3个点,然后就不会了,又想的是 双联通分量,这个不知道为什么不对. Floyd 判断 最小环 #include <iostrea ...

  6. IOS VFL屏幕自适应

    -(void)fun1{ //注意使用VFL,不用设置视图的frame UIView *view = [[UIView alloc] init]; view.backgroundColor = [UI ...

  7. orancle的安装和配置

    1.安装 Oracle 版本:Oracle Database 10g Release 2 (10.2.0.1) 下载地址: http://www.oracle.com/technology/softw ...

  8. CentOS7安装Nginx并部署

    服务器IP是192.168.36.136 1.直接yum install nginx即可 2.主配置文件是/etc/nginx/下的nginx.conf,另外一个是/etc/nginx/conf.d/ ...

  9. How to read a scientific paper

    How to read a scientific paper Nothing makes you feel stupid quite like reading a scientific journal ...

  10. 一段发工资的shell代码

    人事发工资条之前是一个个截图发到我们的邮箱里,看人事妹纸是一个善良而又美丽的姑凉,于是乎写了一段shell代码实现批量发短信至各个手机号.不多说了,上代码,其实很简单,我都不好意思上传,还是记录下吧, ...