[洛谷U22157]刷水题(数位dp)(hash)
题目背景
做正经题是不可能做正经题的,这辈子都不可能做正经题的,毒瘤题又不会做毒瘤题,就是水题这种东西,才维持了蒟蒻的信心;
题目描述
这里有N+1 道水题,编号分别为0 ~N+1 ,每道水题都有它自己水的程度,具体为对应编号的每位上的数字的乘积,现在为了能够更好的刷水题,我们需要统计一点小东西,统计给出L,R,A,B四个值,具体统计的内容为编号在LL 到RR 这段区间中水的程度在A 到B 之间的水题的编号和,现在请你编写一个程序来完成这个统计并A掉这道水题,因为结果可能很大,请输出在对P 取模意义下答案;
输入输出格式
输入格式:
第一行两个整数N,P ,接下来一行四个数L,R,A,B 表示一次询问;
输出格式:
一个整数表示统计的结果;
输入输出样例
说明
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)的更多相关文章
- 洛谷P2657 windy数 [SCOI2009] 数位dp
正解:数位dp 解题报告: 传送门! 这题一看就是个数位dp鸭,"不含前导零且相邻两个数字之差至少为2"这种的 然后就直接套板子鸭(板子戳总结,懒得放链接辣QAQ 然后就是套路 然 ...
- 洛谷P2602 数字计数 [ZJOI2010] 数位dp
正解:数位dp 解题报告: 传送门! 打算在寒假把学长发过题解的题目都做辣然后把不会的知识点都落实辣! ⁄(⁄ ⁄•⁄ω⁄•⁄ ⁄)⁄ 然后这道题,开始想到的时候其实想到的是大模拟,就有点像之前考试贪 ...
- 洛谷P2657 [SCOI2009]windy数 [数位DP,记忆化搜索]
题目传送门 windy数 题目描述 windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道, 在A和B之间,包括A和B,总共有多少个win ...
- 洛谷$P$2518 计数 $[HAOI2010]$ 数位$dp$
正解:数位$dp$ 解题报告: 传送门$w$ 感觉省选的数位$dp$还是比较有质量的辣,,,至少有一定的思维难度是趴$QwQ$ 这题要考虑到一个,我认为比较关键的点,就,对于一个位数不满的数,可以理解 ...
- Mychael原创题 洛谷T23923 Mychaelの水题 【题解】
原题链接 题目大意: 有来自三个地区的人各a,b,c位,他们排成了一排.请问有多少种不同类型的排法,使得相邻的人都来自不同的地区 \(a,b,c<=200\) 答案取模 题解 弱弱的标程解法 设 ...
- 洛谷P2602 [ZJOI2010]数字计数(数位dp)
数字计数 题目传送门 解题思路 用\(dp[i][j][k]\)来表示长度为\(i\)且以\(j\)为开头的数里\(k\)出现的次数. 则转移方程式为:\(dp[i][j][k] += \sum_{t ...
- [洛谷P4626]一道水题 II
题目大意:求$lcm(1,2,3,\cdots,n)\pmod{100000007}$,$n\leqslant10^8$ 题解:先线性筛出质数,然后求每个质数最多出现的次数,可以用$\log_in$来 ...
- 洛谷P1540 机器翻译 水题 模拟
注意一下细节,尤其是更新minv时不要更新错. Code: #include<vector> #include<iostream> #include<cstdio> ...
- [洛谷P1707] 刷题比赛
洛谷题目连接:刷题比赛 题目背景 nodgd是一个喜欢写程序的同学,前不久洛谷OJ横空出世,nodgd同学当然第一时间来到洛谷OJ刷题.于是发生了一系列有趣的事情,他就打算用这些事情来出题恶心大家-- ...
随机推荐
- Javaweb学习笔记4—Reuest&Response
今天来讲javaweb的第四段学习. Request和Response还是比较重要的 老规矩,首先先用一张思维导图来展现今天的博客内容. ps:我的思维是用的xMind画的,如果你对我的思维导图感兴趣 ...
- Cognos报表验证(添加字段)
1.打开后台Cognos 链接远程后台Cognos 2.打开要验证的报表 3.给右边的sql语句加个空格或者换行点击验证 4.查看业务视图中是否已经添加该字段 双击维度或者度量(添加字段所在的分类) ...
- DFS、BFS和Backtracking模板
区别与联系 区别 DFS多用于连通性问题因为其运行思想与人脑的思维很相似,故解决连通性问题更自然,采用递归,编写简便(但我个人不这样觉得...) DFS的常数时间开销会较少.所以对于一些能用DFS就能 ...
- python关于入参中,传入的是指针还是引用
偶然看到别人的代码,发现有的会传入参数之后,做一次copy,试验一下,关于入参中,传入的是指针还是引用先说自己的结论:1.如果传入的是简单的类型,那么传入应该是引用的数值,2.假如传入的是df这种类型 ...
- 清除oracle归档日志
清除oracle归档日志 1. 连接oracle报如下错误 ORA-00257: archiver error. Connect internal only, until freed 产生原因:出现O ...
- 使用iframe引入公共模块
新建一个公共文件head.html <!DOCTYPE html><html lang="en"><head> <meta charset ...
- HTML5编辑API之Range对象
Range对象代表页面上的一段连续区域,通过Range对象,可以获取或修改页面上的任何区域,可以通过如下创建一个空的Range对象,如下: var range = document.createRa ...
- 一个关于vue+mysql+express的全栈项目(四)------ sequelize中部分解释
一.模型的引入 引入db.js const sequelize = require('./db') sequelize本身就是一个对象,他提供了众多的方法, const account = seque ...
- 我的java web之路(JSP基本语法)
1.JSP注释 1.1输出注释 语法格式 <!--comment [<%= expression %>] --> <body> This is my JSP pa ...
- playbacktask
/ ** 播放应用程序的头文件. 此文件是头文件,用于定义Playback应用程序的API和数据类型. @file PlaybackTsk.h @ingroup mIAPPPlay @note什么都没 ...