hdu 4507 数位dp(求和,求平方和)[通俗易懂]

hdu 4507 数位dp(求和,求平方和)

大家好,又见面了,我是全栈君。

http://acm.hdu.edu.cn/showproblem.php?pid=4507

Problem Description
  单身!

  依旧单身!

  吉哥依旧单身!

  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

 

/***
hdu 4507  数位dp(求和,求平方和)
解题思路:dp[len][sum1][sum2] 表示长度为len对7取模为sum1。各位上的数字和为sum2有多少个满足的数
          一个是与7无关的数的个数。就是简单的数位DP了,非经常规。

第二个与7无关的数的和的维护须要用到第一个个数。 处理到第pos个数位时,加上i*10^pos * 后面的个数 第三个的维护须要用到前面两个 (pre*10^pos + next)^2= (pre*10^pos)^2+2*pre*10^pos*next +next^2*/#include <stdio.h>#include <algorithm>#include <string.h>#include <iostream>using namespace std;typedef long long LL;const LL mod=1e9+7;LL l,r,p[25];int bit[25];struct node{ LL cnt,sum,sqsum;} dp[25][10][10];node dfs(int len,int sum1,int sum2,int flag){ if(len<0) { node tmp; tmp.cnt=(sum1!=0&&sum2!=0); tmp.sum=tmp.sqsum=0; return tmp; } if(flag==0&&dp[len][sum1][sum2].cnt!=-1)return dp[len][sum1][sum2]; node ans,tmp; int end=flag?bit[len]:9; ans.cnt=ans.sqsum=ans.sum=0; for(int i=0; i<=end; i++) { if(i==7)continue; tmp=dfs(len-1,(sum1+i)%7,(sum2*10+i)%7,flag&&i==end); ans.cnt+=tmp.cnt; ans.cnt%=mod; ans.sum+=(tmp.sum+i*p[len]%mod*tmp.cnt%mod)%mod; ans.sum%=mod; ans.sqsum+=(tmp.sqsum+2*p[len]*i%mod*tmp.sum%mod)%mod; ans.sqsum%=mod; ans.sqsum+=(tmp.cnt*p[len]%mod*p[len]%mod*i*i%mod); ans.sqsum%=mod; } if(flag==0)dp[len][sum1][sum2]=ans; return ans;}LL solve(LL n){ int len=0; while(n) { bit[len++]=n%10; n/=10; } return dfs(len-1,0,0,1).sqsum;}int main(){ p[0]=1; for(int i=1; i<20; i++) p[i]=(p[i-1]*10)%mod; for(int i=0; i<25; i++) { for(int j=0; j<10; j++) { for(int k=0; k<10; k++) { dp[i][j][k].cnt=-1; } } } int T; scanf("%d",&T); while(T--) { scanf("%I64d%I64d",&l,&r); printf("%I64d\n",((solve(r)-solve(l-1))%mod+mod)%mod); } return 0;}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116251.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 《学习笔记10》——JavaScript三目运算符的使用[通俗易懂]

    《学习笔记10》——JavaScript三目运算符的使用[通俗易懂]三目运算符是多种语言中,都有的一种语法,这里着重讲解JavaScript里的用法。1.判断基本语法:expression?sentence1:sentence2当expression的值为true时,执行sentence1,否则执行sentence2,请看如下代码:3>0?2:1等价于:if(3>0){return2}else{return1}意思是,当3>0成立时,返回2,否则返回1

    2022年6月22日
    31
  • 爬取百度地图 POI 数据

    爬取百度地图 POI 数据

    2021年6月11日
    216
  • 联合索引在B+Tree上的存储结构及数据查找方式[通俗易懂]

    联合索引在B+Tree上的存储结构及数据查找方式[通俗易懂]最困难的事情就是认识自己!个人网站,欢迎访问!前言:本篇文章主要是阐述下联合索引在B+Tree上的实际存储结构。本文主要讲解的内容有:联合索引在B+树上的存储结构联合索引的查找方式为什么会有最左前缀匹配原则在分享这篇文章之前,我在网上查了关于MySQL联合索引在B+树上的存储结构这个问题,翻阅了很多博客和技术文章,其中有几篇讲述的与事实相悖。具体如下:很多博客中都是说:联合索引在B+树上的非叶子节点中只会存储联合索引中的第一个索引字段的.

    2022年6月4日
    27
  • Java实现冒泡排序(详解)[通俗易懂]

    Java实现冒泡排序(详解)[通俗易懂]深度解析冒泡排序算法publicclassMySort{publicstaticvoidbubbleSort(intarray[]){for(inti=0;i<array.length;i++){for(intj=0;j<array.length-1-i;j++){if(array[j]>array[j+1]){

    2022年6月21日
    20
  • 20个数据库常见面试题讲解!「建议收藏」

    20个数据库常见面试题讲解!「建议收藏」进了互联网公司,整天也就是搬砖,等到了面试的时候,发现数据库方面,忘得一塌糊涂,抽时间整理了一些数据库方面的题。欢迎大家向我推荐你在面试过程中遇到的问题,我会把大家推荐的问题添加到下面的常用面试题清单中供大家参考。事务四大特性(ACID)原子性、一致性、隔离性、持久性? 事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL默认是哪个级别? MySQL常见的三种存储引擎(InnoDB…

    2022年6月18日
    31
  • wxPython 入门教程.

    wxPython 入门教程.这篇文章是关于wxPython,但wxPython实际是两件事物的组合体:Python脚本语言和GUI功能的wxWindows库(关于wxWindows的介绍,请参阅developerWorks上的[“细述wxWindows”](http://www.ibm.com/developerworks/cn/linux/sdk/python/wxwin/index.html))。wxWindows库是为了最大可移植性的C/C++库,而抽取GUI功能。所以wxWindow

    2022年5月11日
    32

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号