Beautiful numbers CodeForces - 55D
题意:
找出区间[li,ri]内有多少数满足,这个数的每一个位的非0数都能把这个数整除
题解:
因为这个数每一位的值都可以把这个数整除,那也就是说这个数是它所有位数的公倍数,但是可能不是最小公倍数。
1、2、3、4、5、6、7、8、9的最小公倍数是2520
那么我就可以让我们要判断的那个数去取余2520来实现我们记忆化操作
因为1——9的最小公倍数是2520,所以1——9中任意几个数的最小公倍数肯定是2520的余数,所以我们只需要找出来1——2520之中所有2520的余数就可以了。最后找出来也就48个
给这48个位置每一个映射一个值
这个样子就又可以减小dp数组的大小
dp[x][y][z]表示:枚举到第x位,这个数取余2520的结果是y,这个数目前所有位数的最小公倍数所对应的映射是z
代码:
1 //首先要求能被各位上的数整除,可以转化为被一个数整除问题。
2 //这个数就是各位上数的最小公倍数LCM(不是GCD)。
3 //其次,处理整除问题,得转化成数位DP的余数模板。1~9的LCM最大是2520, 那么%2520,让其可以开数组进行记忆化搜索。
4 //最后, 对于不能%2520最后结果,再%各个数位累计过来的LCM。
5 //这样下来,需要开20*2520*2520的数组,往CF上一交你会发现MLE。
6 //仔细观察每次的LCM,其范围是1~2520没错,但是都是整除gcd的结果(LCM=a*b/gcd(a,b) ),也就是说所有LCM都是某个数的约数。
7 //这个数其实就是2520。所以DP之前,为2520打个表,把LCM给离散化Hash。这样其实只有48个LCM了。数组开20*2520*50即可。
8 //注意结果是int64。
9 #include<stdio.h>
10 #include<string.h>
11 #include<algorithm>
12 #include<iostream>
13 #include<map>
14 using namespace std;
15 const int maxn=20;
16 const int mod=2520;
17 typedef long long ll;
18 ll v[maxn],dp[maxn][mod+50][50];
19 map<ll,ll>w;
20 ll lcm(ll a,ll b)
21 {
22 ll ans=min(a,b);
23 while(ans)
24 {
25 if(a%ans==0 && b%ans==0) break;
26 ans--;
27 }
28 return (a*b)/ans;
29 }
30 ll dfs(ll pos,ll sum,ll sta,bool limit)
31 {
32 if(sta==0)return 0;
33 if(pos==-1)
34 {
35 return sum%sta==0;
36 }
37 if(!limit && dp[pos][sum][w[sta]]!=-1) return dp[pos][sum][w[sta]];
38 ll up=limit?v[pos]:9;
39 ll tmp=0;
40 for(ll i=0;i<=up;++i)
41 {
42 if(i>0)
43 {
44 tmp+=dfs(pos-1,(sum*10+i)%mod,lcm(sta,i),limit && i==v[pos]);
45
46 }
47 else tmp+=dfs(pos-1,(sum*10+i)%mod,sta,limit && i==v[pos]);
48 }
49 if(!limit) dp[pos][sum][w[sta]]=tmp;
50 //只有上界为9的时候才会往dp数组里面存,因为这样能节省更多的时间
51 return tmp;
52 }
53 ll solve(ll ans)
54 {
55 ll pos=0;
56 while(ans)
57 {
58 v[pos++]=ans%10;
59 ans/=10;
60 }
61 return dfs(pos-1,0,1,true);
62 }
63 int main()
64 {
65 ll t,l,r,m=0;
66 scanf("%I64d",&t);
67 for(ll i=1;i<=mod;++i)
68 {
69 if(mod%i==0)
70 {
71 ++m;
72 w[i]=m;
73 }
74 }
75 memset(dp,-1,sizeof(dp));
76 while(t--)
77 {
78 scanf("%I64d%I64d",&l,&r);
79 printf("%I64d\n",solve(r)-solve(l-1));
80 }
81 w.clear();
82 return 0;
83 }
Beautiful numbers CodeForces - 55D的更多相关文章
- codeforces 55d//Beautiful numbers// Codeforces Beta Round #51
题意:一个数能整除它所有的位上的数字(除了0),统计这样数的个数. 注意离散化,为了速度更快需存入数组查找. 不要每次memset,记录下已有的长度下符合条件的个数. 数位dp肯定是从高位到低位. 记 ...
- CodeForces 55D "Beautiful numbers"(数位DP+离散化处理)
传送门 参考资料: [1]:CodeForces 55D Beautiful numbers(数位dp&&离散化) 我的理解: 起初,我先定义一个三维数组 dp[ i ][ j ][ ...
- Codeforces 55D. Beautiful numbers(数位DP,离散化)
Codeforces 55D. Beautiful numbers 题意 求[L,R]区间内有多少个数满足:该数能被其每一位数字都整除(如12,24,15等). 思路 一开始以为是数位DP的水题,觉得 ...
- codeforces 55D - Beautiful numbers(数位DP+离散化)
D. Beautiful numbers time limit per test 4 seconds memory limit per test 256 megabytes input standar ...
- CodeForces 55D Beautiful numbers
D. Beautiful numbers time limit per test 4 seconds memory limit per test 256 megabytes input standar ...
- CodeForces - 55D Beautiful numbers —— 数位DP
题目链接:https://vjudge.net/problem/CodeForces-55D D. Beautiful numbers time limit per test 4 seconds me ...
- CodeForces - 55D - Beautiful numbers(数位DP,离散化)
链接: https://vjudge.net/problem/CodeForces-55D 题意: Volodya is an odd boy and his taste is strange as ...
- Codeforces 55D Beautiful Number
Codeforces 55D Beautiful Number a positive integer number is beautiful if and only if it is divisibl ...
- [codeforces 55]D. Beautiful numbers
[codeforces 55]D. Beautiful numbers 试题描述 Volodya is an odd boy and his taste is strange as well. It ...
随机推荐
- 设置.ignore后不生效解决方案
/logs/*.lock /logs/*.log/reports/API_TEST_V*/.idea/ 设置.ignore后不生效解决方案: 在terminal中输入已下几行代码: git rm -r ...
- Flask+pin
Flask+SSTI的新火花 记一次buu刷题记和回顾祥云杯被虐出屎的经历.题目:[GYCTF2020]FlaskApp 一 题目初见 朴实无华的页面,一个base64的小程序页面 看到有提示. 我就 ...
- vxfs(Veritas File System)扩充目录大小
1.新增加一个磁盘并初始化 # vxdisk list # vxdisksetup -i 3pardata0_22 2.将新增加的磁盘合并到磁盘组中 # vxdg -g testdg01 adddis ...
- luogu P2198 杀蚂蚁
题目描述 经过小FF的研究,他发现蚂蚁们每次都走同一条长度为n个单位的路线进攻, 且蚂蚁们的经过一个单位长度所需的时间为T秒.也就是说,只要小FF在条路线上布防且给蚂蚁造成沉痛伤害就能阻止蚂蚁的进军. ...
- Java基础复习4
选择排序(擂台排序): public class demo1 { public static void main(String[] args) { // TODO Auto- ...
- 干货!上古神器 sed 教程详解,小白也能看的懂
目录: 介绍工作原理正则表达式基本语法数字定址和正则定址基本子命令实战练习 介绍 熟悉 Linux 的同学一定知道大名鼎鼎的 Linux 三剑客,它们是 grep.awk.sed,我们今天要聊的主角就 ...
- 基于Python的接口自动化-unittest测试框架和ddt数据驱动
引言 在编写接口自动化用例时,我们一般针对一个接口建立一个.py文件,一条接口测试用例封装为一个函数(方法),但是在批量执行的过程中,如果其中一条出错,后面的用例就无法执行,还有在运行大量的接口测试用 ...
- Docker部署SayHello(FastAPI)
目录 前言 服务部署 部署后端 1. 进入到sayhello目录 2. 编写API的Dockerfile(如果有请之直接构建镜像- 在下一步) 3. 构建镜像 4. 运行容器 5. 访问IP:8000 ...
- 不识Netty真面目,只缘未读此真经
Netty官网:https://netty.io/ Netty is an asynchronous event-driven network application framework for ra ...
- Java 执行过程中的内存模型
一.前言 本文的主要工作:尝试以时间顺序追踪一遍 Java 执行的整个过程,以及展示 JVM 中内存模型的相应变化. 本文的主要目的:希望能够通过 Java 执行过程的冰山一角,增进对编程语言工作原理 ...