Codeforces 288E - Polo the Penguin and Lucky Numbers(数位 dp+推式子)
纪念自己独立做出来的一道难度 2800 的题。
我们记 \(ans(x)\) 为 \([444...44,x]\) 的答案,显然答案为 \(ans(r)-ans(l)\)
其次我们考虑 \(a_i\) 与 \(a_{i+1}\) 之间有什么联系。
不难发现从 \(a_i\) 变到 \(a_{i+1}\),也就是把 \(a_i\) 末尾一系列 \(7\) 改为 \(4\),再把从右往左数第一个 \(4\) 改为 \(7\)。
这样我们就可以枚举末尾 \(7\) 的个数,假设为 \(cnt\)。
则 \(a_i=xxx...xx4777...77,a_{i+1}=xxx...xx7444...44\)
如果把前面 \(xxx...xx\) 记作 \(X\),那么 \(a_i=X \times 10^{cnt}+4777...77,a_{i+1}=X \times 10^{cnt}+7444...44\)
把 \(a_ia_{i+1}\) 暴力展开,即可得到一个关于 \(X\) 的二次三项式 \(AX^2+BX+C\),其中 \(A,B,C\) 是只与 \(cnt\) 有关的常数,它们具体是什么自己慢慢拆即可,这里就不再赘述了。。
接下来我们就要计算 \(X^2\) 的和,\(X\) 的和以及 \(X\) 的个数,显然可以数位 \(dp\) 预处理。
\(dp[i][0/1]\) 表示考虑到第 \(i\) 位,前 \(i\) 位是否达到上界的答案。
其中 \(dp[i][j]\) 中存三个值:平方和、和、以及个数。
转移可以从 \(dp[i-1][0/1]\) 中转移过来。再根据 \((10x+4)^2=100x^2+80x+16\),\((10x+7)^2=100x^2+140x+49\) 化简。
/*
Contest: -
Problem: Codeforces 288E
Author: tzc_wk
Time: 2020.10.12
*/
#include <bits/stdc++.h>
using namespace std;
#define fi first
#define se second
#define pb push_back
#define fz(i,a,b) for(int i=a;i<=b;i++)
#define fd(i,a,b) for(int i=a;i>=b;i--)
#define foreach(it,v) for(__typeof(v.begin()) it=v.begin();it!=v.end();it++)
#define all(a) a.begin(),a.end()
#define fill0(a) memset(a,0,sizeof(a))
#define fill1(a) memset(a,-1,sizeof(a))
#define fillbig(a) memset(a,0x3f,sizeof(a))
#define y1 y1010101010101
#define y0 y0101010101010
typedef pair<int,int> pii;
typedef long long ll;
const ll MOD=1e9+7;
char s[100005];int n;
struct data{
ll sqr,cnt,sum;
data(ll _sqr=0,ll _sum=0,ll _cnt=0){
sqr=_sqr;sum=_sum;cnt=_cnt;
}
} dp[100005][2];
ll pw[200005],seven[100005],four[100005];
inline data upd4(data p){
return data(
(p.sqr*100ll+p.sum*80ll+p.cnt*16ll)%MOD,
(p.sum*10ll+p.cnt*4ll)%MOD,(p.cnt));
}
inline data upd7(data p){
return data(
(p.sqr*100ll+p.sum*140ll+p.cnt*49ll)%MOD,
(p.sum*10ll+p.cnt*7ll)%MOD,(p.cnt));
}
inline void add(data &x,data y){
x.sqr+=y.sqr;if(x.sqr>=MOD) x.sqr-=MOD;
x.sum+=y.sum;if(x.sum>=MOD) x.sum-=MOD;
x.cnt+=y.cnt;if(x.cnt>=MOD) x.cnt-=MOD;
}
inline ll get(data x,ll k);
inline ll calc(){
scanf("%s",s+1);n=strlen(s+1);
for(int i=0;i<=n;i++) dp[i][0]=dp[i][1]=data(0,0,0);
dp[0][1]=data(0,0,1);
for(int i=1;i<=n;i++){
dp[i][0]=dp[i][1]=data(0,0,0);
if(s[i]=='4'){
add(dp[i][0],upd4(dp[i-1][0]));
add(dp[i][0],upd7(dp[i-1][0]));
add(dp[i][1],upd4(dp[i-1][1]));
}
else{
add(dp[i][0],upd4(dp[i-1][0]));
add(dp[i][0],upd4(dp[i-1][1]));
add(dp[i][0],upd7(dp[i-1][0]));
add(dp[i][1],upd7(dp[i-1][1]));
}
// printf("%lld %lld %lld\n",dp[i][0].sqr,dp[i][0].sum,dp[i][0].cnt);
// printf("%lld %lld %lld\n",dp[i][1].sqr,dp[i][1].sum,dp[i][1].cnt);
}
ll ans=0;
for(int i=0;i<n;i++){
if(s[i+1]=='4'){
ans=(ans+get(dp[i][0],n-i-1))%MOD;
} else{
ans=(ans+get(dp[i][0],n-i-1))%MOD;
ans=(ans+get(dp[i][1],n-i-1))%MOD;
}
}
// printf("%lld\n",ans);
return ans;
}
int main(){
pw[0]=1;for(int i=1;i<=200002;i++) pw[i]=pw[i-1]*10%MOD;
for(int i=1;i<=100000;i++) seven[i]=(seven[i-1]*10+7)%MOD;
for(int i=1;i<=100000;i++) four[i]=(four[i-1]*10+4)%MOD;
ll L=calc(),R=calc();
printf("%lld\n",(R-L+MOD)%MOD);
return 0;
}
inline ll get(data x,ll k){
// printf("%d %d %d\n",x.sqr,x.sum,x.cnt);
return (seven[k]*four[k]%MOD*x.cnt%MOD+seven[k]*pw[k+1]%MOD*x.sum%MOD+
seven[k]*7%MOD*pw[k]%MOD*x.cnt%MOD+four[k]*pw[k+1]%MOD*x.sum%MOD+
four[k]*4%MOD*pw[k]%MOD*x.cnt%MOD+pw[(k<<1)+2]*x.sqr%MOD+
110*pw[k<<1]%MOD*x.sum%MOD+28*pw[k<<1]%MOD*x.cnt%MOD)%MOD;
}
Codeforces 288E - Polo the Penguin and Lucky Numbers(数位 dp+推式子)的更多相关文章
- Codeforces 914 C. Travelling Salesman and Special Numbers (数位DP)
题目链接:Travelling Salesman and Special Numbers 题意: 给出一个二进制数n,每次操作可以将这个数变为其二进制数位上所有1的和(3->2 ; 7-> ...
- 2018 ACM 国际大学生程序设计竞赛上海大都会赛重现赛 J Beautiful Numbers (数位DP)
2018 ACM 国际大学生程序设计竞赛上海大都会赛重现赛 J Beautiful Numbers (数位DP) 链接:https://ac.nowcoder.com/acm/contest/163/ ...
- codeforces 55D - Beautiful numbers(数位DP+离散化)
D. Beautiful numbers time limit per test 4 seconds memory limit per test 256 megabytes input standar ...
- Codeforces Beta Round #51 D. Beautiful numbers 数位dp
D. Beautiful numbers Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/55/p ...
- Codeforces Gym 100418J Lucky tickets 数位DP
Lucky ticketsTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/view ...
- Educational Codeforces Round 8 D. Magic Numbers 数位DP
D. Magic Numbers 题目连接: http://www.codeforces.com/contest/628/problem/D Description Consider the deci ...
- Codeforces Gym100623J:Just Too Lucky(数位DP)
http://codeforces.com/gym/100623/attachments 题意:问1到n里面有多少个数满足:本身被其各个数位加起来的和整除.例如120 % 3 == 0,111 % 3 ...
- CodeForces 628 D Magic Numbers 数位DP
Magic Numbers 题意: 题意比较难读:首先对于一个串来说, 如果他是d-串, 那么他的第偶数个字符都是是d,第奇数个字符都不是d. 然后求[L, R]里面的多少个数是d-串,且是m的倍数. ...
- CodeForces - 55D - Beautiful numbers(数位DP,离散化)
链接: https://vjudge.net/problem/CodeForces-55D 题意: Volodya is an odd boy and his taste is strange as ...
随机推荐
- windows环境下基于pycharm安装Redis出现的两个错误解决方案
说明:下面给出的两个链接是解决安装和使用Redis的时候遇到的两个问题参考的博客网址,本文有解释不清楚的地方可以原博客查看,侵权删! Q1参考链接-https://blog.csdn.net/maqu ...
- Scrum Meeting 0503
零.说明 日期:2021-5-3 任务:简要汇报两日内已完成任务,计划后两日完成任务 一.进度情况 组员 负责 两日内已完成的任务 后两日计划完成的任务 qsy PM&前端 完成登录.后端管理 ...
- [no_code]OCR表格处理——技术规格说明书
项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 技术规格说明书 我们在这个课程的目标是 远程协同工作,采用最新技术开发软件 这个作业在哪个具体方面 ...
- RAW RGB格式
RAW RGB格式 10bit Raw RGB, 就是说用10bit去表示一个R, G, 或者B, 通常的都是用8bit的. 所以你后面处理时要把它转换为8bit的, 比较简单的方法就是将低两位去掉, ...
- 认识Linux系统中的inode,硬链接和软链接
在学习和创建软链接遇到了一点问题,总结一下: 在当前文件夹下面建立了两个临时文件夹tempdir1和tempdir2,然后在tempdir2里面创建了一个hello文件,然后用指令ln -s temp ...
- ubuntn 一直循环登录界面 (卸载nvidia驱动)
由于在Ubuntu下安装了Nvidia显卡驱动后开机一直处于循环登录界面,密码输入正确也是进不去,然后就决定卸载Nvidia显卡驱动.首先是在能使用tty1登录的情况下,使用 $ sudo apt-g ...
- no space left on device 磁盘空间不足
新挂载的目录,创建文件提示:no space left on device 1.执行命令:df -h ,查看盘是否挂载成功 2.用history命令查看历史命令,尴尬的发现挂载前忘记格式化了 3.取消 ...
- Windows内核中的CPU架构-6-中断门(32-Bit Interrupt Gate)
Windows内核中的CPU架构-6-中断门(32-Bit Interrupt Gate) 中断门和调用门类似,也是一种系统段.同样的它也可以用来提权. 中断门: 虽然中断门的段描述符如下: 但是中断 ...
- void * 是什么?
最近遇到void *的问题无法解决,发现再也无法逃避了(以前都是采取悄悄绕过原则),于是我决定直面它. 在哪遇到了? 线程创建函数pthread_create()的最后一个参数void *arg,嗯? ...
- robot_framewok自动化测试--(6)Collections 库
Collections 库 Collections 库同样为 Robot Framework 标准类库,它所提供的关键字主要用于列表.索引.字典的处理. 在使用之前需要在测试套件(项目)中添加: 1. ...