题目描述

单身!

依然单身!

吉哥依然单身!

DS级码农吉哥依然单身!

所以,他生平最恨情人节,不管是214还是77,他都讨厌!

吉哥观察了214和77这两个数,发现:

2+1+4=7
7+7=7*2
77=7*11

最终,他发现原来这一切归根到底都是因为和\(7\)有关!所以,他现在甚至讨厌一切和7有关的数!

什么样的数和\(7\)有关呢?

如果一个整数符合下面\(3\)个条件之一,那么我们就说这个整数和\(7\)有关——

  1. 整数中某一位是\(7\);
  2. 整数的每一位加起来的和是\(7\)的整数倍;
  3. 这个整数是\(7\)的整数倍;

现在问题来了:吉哥想知道在一定区间内和\(7\)无关的数字的平方和。

Input

输入数据的第一行是\(case\)数\(T(1 <= T <= 50)\),然后接下来的\(T\)行表示\(T\)个\(case\);

每个\(case\)在一行内包含两个正整数\(L, R(1 <= L <= R <= 10^{18})\)。

Output

请计算\([L,R]\)中和\(7\)无关的数字的平方和,并将结果对\(10^{9}+7\)求模后输出。

Sample Input

3
1 9
10 11
17 17

Sample Output

236
221
0

数位\(dp\)题。

以前,我们遇到的数位\(dp\)题,都是求区间满足条件的数的个数。

那区间平方和怎么维护呢?

其实,区间平方和也可以做差求解。

那么,\(dp\)的同时需要维护\(3\)个值,开个结构体存一下就行了。

让我们一位位的进行计算。

1.满足条件的数的个数。这个利用普通的数位\(dp\)去维护就行了。

2.满足条件的数的和。这个维护时,加上子状态的值,以及该状态的位数和子状态的个数。

\(12=(1*10^{1}+2*10^{0})\)

因为我们枚举当前的位置\(x\)上放了\(i\),则i在原数中对应\(i*10^{x}\)

\(1\)是你当前枚举的数字,\(2*10^{0}\)是你子状态的答案,所以状态的转移也就出来了。

当前sum=子状态sum+当前位的数字\(10^{当前位数}\)子状态个数。

3.满足条件的数的平方和。这个维护时,加上子状态的值,以及该状态的位数和子状态的个数。

\(12^{2}=(1*10^{1}+2*10^{0})^{2}\)

\(12^{2}=1^{2}*(10^{1})^{2}+(2*10^{0})^{2}+2*(2*10^{0})*(1*10^{1})\)

让我们回顾一下平方和公式:

\((a+b)^{2}=a^{2}+b^{2}+2*a*b\)

\(a\)就是当前位\(i*10^{当前位数}\),\(b\)是子状态和。

状态的转移也就出来了。

当前平方和=子状态平方和+\(2*i∗10^{当前位数}*子状态和\)+\((i∗10^{当前位数})^{2}*子状态个数\)

注意,取模后记得负数要加上模数再取模。

代码如下

#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
const int mod=1000000007;
int T,num[25];
long long a,b,pow[20]={0,1};
struct node {
long long cnt,sum,qsum;
} dp[25][15][15];
node dfs(int pos,int mod1,int mod2,int limit) {
if(pos==0)return <%mod1&&mod2,0,0%>;
if(!limit&&dp[pos][mod1][mod2].cnt!=-1)return dp[pos][mod1][mod2];
int up=limit?num[pos]:9;
node res=<%0,0,0%>;
for(int i=0; i<=up; i++) {
if(i==7)continue;
node temp=dfs(pos-1,(mod1+i)%7,(mod2*10+i)%7,limit&(i==up));
res.cnt=(res.cnt+temp.cnt)%mod;
res.sum=(res.sum+temp.sum)%mod;
res.sum=(res.sum+((i*pow[pos])%mod)*temp.cnt%mod)%mod;
res.qsum=(res.qsum+temp.qsum%mod)%mod;
res.qsum=(res.qsum+((2*pow[pos]*i)%mod*temp.sum%mod)%mod)%mod;
res.qsum=(res.qsum+((pow[pos]*pow[pos])%mod*temp.cnt%mod*(i*i)%mod)%mod);
}
if(!limit)dp[pos][mod1][mod2]=res;
return res;
}
long long solve(long long n) {
int len=0;
while(n)num[++len]=n%10,n/=10;
return dfs(len,0,0,1).qsum;
}
int main() {
scanf("%d",&T);
for(int i=2;i<20;i++)pow[i]=(pow[i-1]*10)%mod;
for(int i=0; i<=20; i++)
for(int j=0; j<=10; j++)
for(int k=0; k<=10; k++)dp[i][j][k]=<%-1,0,0%>;
while(T--) {
scanf("%lld%lld",&a,&b);
printf("%lld\n",(((solve(b)-solve(a-1))%mod+mod)%mod));
}
}

HDU-4507-吉哥系列故事-恨7不成妻的更多相关文章

  1. HDU - 4507 - 吉哥系列故事——恨7不成妻(数位DP,数学)

    链接: https://vjudge.net/problem/HDU-4507 题意: 单身! 依然单身! 吉哥依然单身! DS级码农吉哥依然单身! 所以,他生平最恨情人节,不管是214还是77,他都 ...

  2. HDU 4507 吉哥系列故事――恨7不成妻(数位DP+结构体)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4507 题目大意:如果一个整数符合下面3个条件之一,那么我们就说这个整数和7有关 1.整数中某一位是7: ...

  3. HDU 4507 吉哥系列故事——恨7不成妻

    需要推下平方和的式子..维护个数,和,平方和. #include<iostream> #include<cstdio> #include<cstring> #inc ...

  4. HDU 4507 吉哥系列故事——恨7不成妻 (数位DP)

    题意: 如果一个整数符合下面3个条件之一,那么我们就说这个整数和7有关: 1.整数中某一位是7: 2.整数的每一位加起来的和是7的整数倍: 3.这个整数是7的整数倍: 给定一个区间[L,R],问在此区 ...

  5. HUD 4507 吉哥系列故事——恨7不成妻

    传送门 三个限制都可以数位 $dp$ , $dfs$ 是维护当前位,之前各位总和模 $7$ 意义下的值,之前填的数模 $7$ 意义下的值,是否贴着限制 主要现在求的是各个合法数的平方的和,比较恶心 开 ...

  6. 吉哥系列故事——恨7不成妻(数位DP)

    吉哥系列故事——恨7不成妻 http://acm.hdu.edu.cn/showproblem.php?pid=4507 Time Limit: 1000/500 MS (Java/Others)   ...

  7. [HDU4507]吉哥系列故事——恨7不成妻

    [HDU4507]吉哥系列故事--恨7不成妻 试题描述 单身!依然单身!吉哥依然单身!DS级码农吉哥依然单身!所以,他生平最恨情人节,不管是214还是77,他都讨厌!吉哥观察了214和77这两个数,发 ...

  8. 吉哥系列故事——恨7不成妻(数位dp)

    吉哥系列故事--恨7不成妻 传送门 Problem Description 单身! 依然单身! 吉哥依然单身! DS级码农吉哥依然单身! 所以,他生平最恨情人节,不管是214还是77,他都讨厌! 吉哥 ...

  9. Day9 - J - 吉哥系列故事——恨7不成妻 HDU - 4507

    单身! 依然单身! 吉哥依然单身! DS级码农吉哥依然单身! 所以,他生平最恨情人节,不管是214还是77,他都讨厌! 吉哥观察了214和77这两个数,发现: 2+1+4=7 7+7=7*2 77=7 ...

  10. 吉哥系列故事――恨7不成妻 HDU - 4507

    题目: 单身! 依然单身! 吉哥依然单身! DS级码农吉哥依然单身! 所以,他生平最恨情人节,不管是214还是77,他都讨厌! 吉哥观察了214和77这两个数,发现: 2+1+4=7 7+7=7*2 ...

随机推荐

  1. laravel短信验证

    短信验证按钮倒计时功能: $('.btn').click(function(){ var time = 59; // $('.btn').css('background-color','#ccc'); ...

  2. redis安装成功后get: command not found

    安装redis后客户端无法使用,即redis-cli执行后报找不到的错误. 这主要是安装redis的时候没有把客户端装上,在StackOverFlow上找到了一种只安装redis cli的方法. 安装 ...

  3. python爬取智联招聘职位信息(多进程)

    测试了下,采用单进程爬取5000条数据大概需要22分钟,速度太慢了点.我们把脚本改进下,采用多进程. 首先获取所有要爬取的URL,在这里不建议使用集合,字典或列表的数据类型来保存这些URL,因为数据量 ...

  4. Unity3D_(游戏)卡牌03_选关界面

      启动屏界面.主菜单界面.选关界面.游戏界面 卡牌01_启动屏界面 传送门 卡牌02_主菜单界面 传送门 卡牌03_选关界面 传送门 卡牌04_游戏界面    传送门 选关界面效果 (鼠标放在不同关 ...

  5. ...扩展运算符+rest参数+call/apply/bind

    之前在set,map里面有提过扩展运算符的概念,但是今天偶然遇到一个问题,类似于扩展运算符的经典用法,突然发现对其了解不是很深,所以再来整理一下扩展运算符的相关知识. 重点:扩展运算符内部调用的是数据 ...

  6. sqli-labs(38)

    0X01 ?id=' and 1=1%23 正确 ?id=1' and 1=2%23 错误 存在注入 0x1 堆叠注入讲解 (1)前言 国内有的称为堆查询注入,也有称之为堆叠注入.个人认为称之为堆叠注 ...

  7. centos6 yum安装mysql 5.6 (完整版)

    使用源代码编译安装mysql还是比较麻烦,一般来说设备安装时请网络同事临时开通linux上网,通过yum网络实现快速安装,或配置yum仓库进行内网统一安装. 通过网络快速安装过程如下 一.检查系统是否 ...

  8. webSocket通信

    针对webSocket通信总结: 1.webSocket通信原理图: 2.webSocket通信实例 参考地址1:https://www.cnblogs.com/cjm123/p/9674506.ht ...

  9. Uep弹窗showModalDialog的使用

    function imageMaintain() { $.showModalDialog($$pageContextPath + "uepI/imageMaintain.do?service ...

  10. 精简版 Selenium PageFactory, Annotation 实例

    精简版 Selenium  PageFactory, Annotation 实例. 先是类: HomePage package com.test;import org.openqa.selenium. ...