2018.07.26NOIP模拟 魔法数字(数位dp)
魔法数字
题目背景
ASDFZ-NOIP2016模拟
题目描述
在数论领域中,人们研究的基础莫过于数字的整除关系。一般情况下,我们说整除总在两个数字间进行,例如 a | b(a能整除b)表示 b 除以 a 的余数为 0 。
我们称一个数字 X 是魔法的,当且仅当 X 是整数,且它能被 K 及 K 以上种一位数整除,要求这若干种一位数均在 X 的十进制表示中出现。
给出整数 K、L、R,请你计算出在区间 [L,R] 中,有多少个魔法数字。
输入格式
输入一行三个整数 K、L、R。
输出格式
输出一行一个整数,表示该区间内魔法数字的个数。
样例数据 1
输入
2 1 20
输出
2
备注
【数据范围】
对于 30% 的数据,1≤L≤R≤105;
对于 50% 的数据,1≤L≤R≤106;
对于 70% 的数据,1≤L≤R≤109;
对于 100% 的数据,1≤L≤R≤1018;0≤K≤9。
数位dp" role="presentation" style="position: relative;">dpdp,f[i][j][k][0/1]" role="presentation" style="position: relative;">f[i][j][k][0/1]f[i][j][k][0/1]表示当dp" role="presentation" style="position: relative;">dpdp到第i" role="presentation" style="position: relative;">ii位,当前对252" role="presentation" style="position: relative;">252252取模余数是j" role="presentation" style="position: relative;">jj,已经满足条件的数字的状态为k" role="presentation" style="position: relative;">kk(二进制压位),当前位的选取是否受到限制。
然后写一发记搜应该就能过了吧。
代码:
#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll f[20][253][520][2],L,R;
int stat[2520],k,len,num[20];
inline int cntsolve(int x){
int ret=0;
while(x)x-=x&(-x),++ret;
return ret;
}
inline ll dfs(int pos,int mod,int sta,int lim){
if(pos>len){
mod-=mod/2520*2520;
if(cntsolve(sta&stat[mod])>=k){return 1;}
return 0;
}
mod-=mod/252*252;
if(~f[pos][mod][sta][lim])return f[pos][mod][sta][lim];
int up=lim?num[pos]:9;
ll ret=0ll;
for(register int i=0;i<=up;++i)ret+=dfs(pos+1,mod*10+i,(i==0)?sta:(sta|(1<<(i-1))),lim&&(i==up));
return f[pos][mod][sta][lim]=ret;
}
inline ll solve(ll x){
len=0,memset(f,-1,sizeof(f));
while(x)num[++len]=x-x/10*10,x/=10;
reverse(num+1,num+len+1);
return dfs(1,0,0,1);
}
int main(){
scanf("%d%lld%lld",&k,&L,&R);
for(register int i=1;i<=9;++i)
for(register int j=0;j<2520;j+=i)
stat[j]|=(1<<(i-1));
printf("%lld",solve(R)-solve(L-1));
return 0;
}
2018.07.26NOIP模拟 魔法数字(数位dp)的更多相关文章
- 【2018.06.26NOIP模拟】T2号码bachelor 【数位DP】*
[2018.06.26NOIP模拟]T2号码bachelor 题目描述 Mike 正在在忙碌地发着各种各样的的短信.旁边的同学 Tom 注意到,Mike 发出短信的接收方手机号码似乎都满足着特别的性质 ...
- 【2018.06.26NOIP模拟】T3节目parade 【支配树】*
[2018.06.26NOIP模拟]T3节目parade 题目描述 学校一年一度的学生艺术节开始啦!在这次的艺术节上总共有 N 个节目,并且总共也有 N 个舞台供大家表演.其中第 i 个节目的表演时间 ...
- 【2018.06.26NOIP模拟】T1纪念碑square 【线段树】*
[2018.06.26NOIP模拟]T1纪念碑square 题目描述 2034年,纪念中学决定修建校庆100周年纪念碑,作为杰出校友的你被找了过来,帮校方确定纪念碑的选址. 纪念中学的土地可以看作是一 ...
- 2018.06.26 NOIP模拟 号码(数位dp)
题目背景 SOURCE:NOIP2015-GDZSJNZX(难) 题目描述 Mike 正在在忙碌地发着各种各样的的短信.旁边的同学 Tom 注意到,Mike 发出短信的接收方手机号码似乎都满足着特别的 ...
- 2018.09.07 Amount of degrees(数位dp)
描述 求给定区间[X,Y]中满足下列条件的整数个数:这个数恰好等于K个互不相等的B的整数次幂之和. 例如,设X=15,Y=20,K=2,B=2,则有且仅有下列三个数满足题意: 17 = 24+20, ...
- 2018.08.18 NOIP模拟 game(数位dp)
Game 题目背景 SOURCE:NOIP2015-SHY4 题目描述 Alice 和 Bob 正在玩一个游戏,两个人从 1 轮流开始报数,如果遇到 7 的倍数或者遇到的这个数的十进制表示中含 7 , ...
- xbz分组题B 吉利数字 数位dp入门
B吉利数字时限:1s [题目描述]算卦大湿biboyouyun最近得出一个神奇的结论,如果一个数字,它的各个数位相加能够被10整除,则称它为吉利数.现在叫你计算某个区间内有多少个吉利数字. [输入]第 ...
- 2018上海大都会邀请赛J(数位DP)
#include<bits/stdc++.h>using namespace std;int num[20];//按位储存数字int mod;long long dp[20][110][1 ...
- 牛客小白月赛8 - E - 诡异数字 数位DP
牛客小白月赛8 - E - 诡异数字 题意: 求区间中,满足限制条件的数字的个数. 限制条件就是某些数字不能连续出现几次. 思路: 比较裸的数位DP, DP数组开一个dp[len][x][cnt] 表 ...
随机推荐
- 前端-CSS-7-标准文档流&行内元素和块级元素转换
1.什么是标准文档流 <!-- 什么是标准文档流 宏观的将,我们的web页面和ps等设计软件有本质的区别 web 网页的制作 是个“流” 从上而下 ,像 “织毛衣” 而设计软件 ,想往哪里画东 ...
- 前端-HTML练习题
本小节重点: 熟练使用div+span布局,知道div和span的语义化的意思 熟悉对div.ul.li.span.a.img.table.form.input标签有深刻的认知,初期也了解他们,知道他 ...
- apiCloud事件发送与监听
apiCloud事件发送与监听 1.sendEvent 将任意一个自定义事件广播出去,该事件可在任意页面通过 addEventListener 监听收到. sendEvent({params}) 2. ...
- DB分布式 跨库分页
DB分布式-两种方式 1. JDBC扩展 sharding-jdbc: 直接封装JDBC,代码迁移成本低,适用于任何连接池及ORM框架,JAR包提供服务,未使用中间层,不用额外部署,DBA无需 ...
- 转载:canal数据库同步redis
ref: http://blog.csdn.net/tb3039450/article/details/53928351
- Haskell语言学习笔记(65)Data.HashMap
安装 unordered-containers $ cabal install unordered-containers Installed unordered-containers-0.2.9.0 ...
- nstall neovim on Ubuntu 16.04
https://neovim.io/ To install NeoVim on Ubuntu, run 1 2 3 sudo add-apt-repository ppa:neovim-ppa/sta ...
- 大型运输行业实战_day09_1_日期转换与My97DatePicker插件使用
1.日期转换 1.1字符串类型转换成时间Date类型 /** * 给定字符串 转变 为 Date 类型 * @param date 时间 * @param format 时间格式 如:yyyy-MM- ...
- Oracle Client安装报错
Oracle Client安装报错:引用数据不可用于验证此操作系统分发的先决条件 http://tunps.com/p/11797.html 原因是Oracle Client 11g版本不支持最新的W ...
- chrome input去除黄色背景色
input:-webkit-autofill { -webkit-box-shadow: 0 0 0px 1000px white inset; border: 1px solid #CCC!impo ...