题目背景


做正经题是不可能做正经题的,这辈子都不可能做正经题的,毒瘤题又不会做毒瘤题,就是水题这种东西,才维持了蒟蒻的信心;

题目描述


这里有N+1 道水题,编号分别为0 ~N+1 ,每道水题都有它自己水的程度,具体为对应编号的每位上的数字的乘积,现在为了能够更好的刷水题,我们需要统计一点小东西,统计给出L,R,A,B四个值,具体统计的内容为编号在LL 到RR 这段区间中水的程度在A 到B 之间的水题的编号和,现在请你编写一个程序来完成这个统计并A掉这道水题,因为结果可能很大,请输出在对P 取模意义下答案;

输入输出格式


输入格式:

第一行两个整数N,P ,接下来一行四个数L,R,A,B 表示一次询问;

输出格式:


一个整数表示统计的结果;

输入输出样例


输入样例#1:

    
输出样例#1: 

说明


0<=N,A,B<=1e18,1<=L<=R<=N,2<= P <= 1e9 +7

%20数据满足A = 0

另外%80数据满足A > 0。

因为是出现过的题,但是我把它的询问方式加强了,所以我就不出部分分了。

分析:


详情见scoi2012blinker的仰慕者,对于那道题询问来说是对于定值k的统计结果,这道题询问的是A - B的统计结果。

但我们发现对于所有数可能的水的程度只可能有40000多种,因为质因子只有2,3,5,7

所以hash一遍后,挨个挨个暴力计算即可

对于N这个数我都设为1e18了,233

AC代码:


# include <iostream>
# include <cstdio>
# include <map>
# include <cstring>
# include <algorithm>
using namespace std;
const int M = ;
const int N = ;
typedef long long LL;
LL mod;
LL L,R,P,state[N],sum[][N],num[][N],p[],c[],K,a[],b[],A,B;int tot,hs[M],z;
void insert(LL x)
{
int k = x % M;
while(hs[k])
{
++k;
if(k >= M)k = ;
}
hs[k] = ++tot;state[hs[k]] = x;
if(!x)z = tot;
}
int id(LL x)
{
int k = x % M;
while(hs[k])
{
if(state[hs[k]] == x)return hs[k];
++k;if(k >= M)k = ;
}
return ;
}
void init()
{
p[] = ;
for(int i = ;i <= ;i++)p[i] = p[i - ] * 10LL % mod;
for(int i = ;i <= ;i++)
{
insert(i);
num[][id(i)] = ;sum[][id(i)] = i;
}
for(int i = ;i <= ;i++)
{
int tmp = tot;
for(int j = ;j <= tmp;j++)
{
LL x = state[j];int v = j,u;
for(LL k = ;k <= ;k++)
{
if(!id(x * k))insert(x * k);
u = id(x * k);
(num[i + ][u] += num[i][v]) %= mod;
(sum[i + ][u] += (sum[i][v] + (k * p[i]) % mod * num[i][v]) % mod) %= mod;
}
}
}
for(int i = ;i <= ;i++)
{
for(int j = ;j <= tot;j++)
{
a[i] = (a[i] + num[i][j]) % mod;
b[i] = (b[i] + sum[i][j]) % mod;
}
}
}
LL dfs(int t,LL pre,LL now,bool lim,bool first)
{
if(!t)return now == ? pre : ;
int u = id(now);
if(!lim && !first)
{
return ((pre * num[t][u]) % mod * p[t] % mod + sum[t][u]) % mod;
}
int q = lim ? c[t] : 9LL;
LL res = ;
for(LL k = ;k <= q;k++)
{
if(now % k)continue;
(res += dfs(t - ,(pre * p[] + k) % mod,now / k,lim && k == q,first && !k)) %= mod;
}
if(first)(res += dfs(t - ,pre,now,lim && !q,first)) %= mod;
return res;
}
LL Dfs(int t,LL pre,bool now,bool lim,bool first)
{
if(!t)return now ? pre : ;
if(!lim && !first)
{
if(!now)
return ((pre * num[t][z]) % mod * p[t] % mod + sum[t][z]) % mod;
return ((pre * a[t]) % mod * p[t] % mod + b[t]) % mod;
}
int q = lim ? c[t] : ;
LL res = ;
for(LL k = ;k <= q;k++)
{
(res += Dfs(t - ,(pre * p[] + k) % mod,now || (!first && !k),lim && k == q,first && !k)) %= mod;
}
return res;
}
LL solve(LL r)
{
int len = ;
while(r)
{
c[++len] = r % p[];
r /= p[];
}
if(!len)c[len = ] = ;
LL ret = ;
if(A == )ret += Dfs(len,,false,true,true);
for(int i = ;i <= tot;i++)if(state[i] >= A && state[i] <= B)
(ret += dfs(len,,state[i],true,true)) %= mod;
return ret;
}
int main()
{
scanf("%lld %lld",&A,&mod);
init();
scanf("%lld %lld %lld %lld",&L,&R,&A,&B);
printf("%lld\n",((solve(R) - solve(L - )) % mod + mod) % mod);
}

[洛谷U22157]刷水题(数位dp)(hash)的更多相关文章

  1. 洛谷P2657 windy数 [SCOI2009] 数位dp

    正解:数位dp 解题报告: 传送门! 这题一看就是个数位dp鸭,"不含前导零且相邻两个数字之差至少为2"这种的 然后就直接套板子鸭(板子戳总结,懒得放链接辣QAQ 然后就是套路 然 ...

  2. 洛谷P2602 数字计数 [ZJOI2010] 数位dp

    正解:数位dp 解题报告: 传送门! 打算在寒假把学长发过题解的题目都做辣然后把不会的知识点都落实辣! ⁄(⁄ ⁄•⁄ω⁄•⁄ ⁄)⁄ 然后这道题,开始想到的时候其实想到的是大模拟,就有点像之前考试贪 ...

  3. 洛谷P2657 [SCOI2009]windy数 [数位DP,记忆化搜索]

    题目传送门 windy数 题目描述 windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道, 在A和B之间,包括A和B,总共有多少个win ...

  4. 洛谷$P$2518 计数 $[HAOI2010]$ 数位$dp$

    正解:数位$dp$ 解题报告: 传送门$w$ 感觉省选的数位$dp$还是比较有质量的辣,,,至少有一定的思维难度是趴$QwQ$ 这题要考虑到一个,我认为比较关键的点,就,对于一个位数不满的数,可以理解 ...

  5. Mychael原创题 洛谷T23923 Mychaelの水题 【题解】

    原题链接 题目大意: 有来自三个地区的人各a,b,c位,他们排成了一排.请问有多少种不同类型的排法,使得相邻的人都来自不同的地区 \(a,b,c<=200\) 答案取模 题解 弱弱的标程解法 设 ...

  6. 洛谷P2602 [ZJOI2010]数字计数(数位dp)

    数字计数 题目传送门 解题思路 用\(dp[i][j][k]\)来表示长度为\(i\)且以\(j\)为开头的数里\(k\)出现的次数. 则转移方程式为:\(dp[i][j][k] += \sum_{t ...

  7. [洛谷P4626]一道水题 II

    题目大意:求$lcm(1,2,3,\cdots,n)\pmod{100000007}$,$n\leqslant10^8$ 题解:先线性筛出质数,然后求每个质数最多出现的次数,可以用$\log_in$来 ...

  8. 洛谷P1540 机器翻译 水题 模拟

    注意一下细节,尤其是更新minv时不要更新错. Code: #include<vector> #include<iostream> #include<cstdio> ...

  9. [洛谷P1707] 刷题比赛

    洛谷题目连接:刷题比赛 题目背景 nodgd是一个喜欢写程序的同学,前不久洛谷OJ横空出世,nodgd同学当然第一时间来到洛谷OJ刷题.于是发生了一系列有趣的事情,他就打算用这些事情来出题恶心大家-- ...

随机推荐

  1. 中间件及tomcat的内存溢出调优

    主要是这三个选项的调整需要根据主机的内存配置 以及业务量的使用情况调节 -Xmx4g -Xms4g -Xmn2g xmx 与xms一般设置为一样 xmn大致设置为xmx xms的三分之一   可以使用 ...

  2. 什么是WebSocket (经常听别人讲感觉很高大上其实不然)

    WebSocket 协议在2008年诞生,2011年成为国际标准.现在所有浏览器都已经支持了.WebSocket 的最大特点就是,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真 ...

  3. xlsx 读取文件日期问题

    xlsx 的版本:0.13.5,可以取到日期 xlsx 的版本:0.14.3,取到的日期转为数字了,没有找到方法转为日期, 可以开启   cellDates: true,但是这个时区不对, dateN ...

  4. fio测试nvme性能

    #cat /sys/block/nvme0n1/queue/scheduler none #cat /sys/block/sda/queue/scheduler noop deadline [cfq] ...

  5. sublime中项目无法添加文件夹

    问题记录 mac中,使用vue init webpack project 后,在sublime中打开,但是添加新文件夹和删除,总提示没有权限, 然后用git提交吧 也不行,每次都要sudo 出现的提示 ...

  6. mysql5.7zip安装

    一.下载mysql zip文件 二.解压.(我的目录A:\mysql\mysql-5.7.23-winx64) 三.配置环境变量   Path后面追加%A:\mysql\mysql-5.7.23-wi ...

  7. ubuntu修改网卡名称ensX为eth0

    1.sudo nano /etc/default/grub 找到GRUB_CMDLINE_LINUX="" 改为GRUB_CMDLINE_LINUX="net.ifnam ...

  8. 转: 使用 /sys 文件系统访问 Linux 内核

    转一个挺不错的文章 使用 /sys 文件系统访问 Linux 内核 https://www.ibm.com/developerworks/cn/linux/l-cn-sysfs/ 如果你正在开发的设备 ...

  9. ES5的数组方法

    参考:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array Array.prot ...

  10. rspec测试(使用guard自动测试和spork加速测试)配置

    Gemfile文件添加rspec.guard和spork,之后执行bundle install命令 gem 'rb-readline' group :development, :test do # C ...