hdu 5435 A serious math problem
A serious math problem
Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Problem Description
Xiao Jun likes math and he has a serious math question for you to finish.
Define \(F[x]\) to the \(xor\) sum of all digits of \(x\) under the decimal system,for example \(F(1234) = 1\ xor\ 2\ xor\ 3\ xor\ 4 = 4\).
Two numbers \(a,b(a≤b)\) are given,figure out the answer of \(F[a] + F[a+1] + F[a+2]+…+ F[b−2] + F[b−1] + F[b]\) doing a modulo \(10^9+7\).
Input
The first line of the input is a single integer \(T(T<26)\), indicating the number of testcases.
Then \(T\) testcases follow.In each testcase print three lines :
The first line contains one integers \(a\).
The second line contains one integers \(b\).
\(1≤|a|,|b|≤100001\),\(|a|\) means the length of \(a\).
Output
For each test case, output one line "Case #x: y", where x is the case number (starting from 1) and y is the answer.
Sample Input
4
0
1
2
2
1
10
9999
99999
Sample Output
Case #1: 1
Case #2: 2
Case #3: 46
Case #4: 649032
Source
BestCoder Round #55 ($)
这就是数位dp。。。。又想起了当年我作为一个被毒害的小朋友去写windy数的恐惧(哪天再去做一遍233)
我们来简单说一下这道题的做法:
\(dp[i][j]\) 表示\(i\)位数,异或值为\(j\)的数的个数。\((e.g.\ 0-9\ 10 - 99\ 100 - 999\ ......)\)
表示这个转移很暴力~~(代码展示---)
然而数位dp和别的不同的是,dp其实只是你的预处理。。。。你可能还要计数。。。(蒟蒻表示计数比dp难)
需要我们做的操作是求出所有小于等于\(a\)的自然数的异或值的和。而我们预处理的是很多个区间的答案,所以我们还要统计一下。
我们需要把\(a\)这个数给拆成很多个区间。。。
举个栗子:
\(3122=(0~999)+(1000~1999) + (2000~2999) + (3000 ~ 3589)\)
\((3000~3122)=(3000~3099)+(3100~3122)\)
\((3100~3122)=(3100~3109) + (3110~3119) + (3120~3122)\)
按这种方法分解以后,我们就和计数啦~
(注意:代码中可以看出,我们传进去是\(a\),实际上返回的是\(a-1\)的答案,所以适当调整一下~)
#include<bits/stdc++.h>
using namespace std;
const int maxn = 100005, mod = 1e9 + 7;
char a[maxn], b[maxn];
int dp[maxn][20], ans[20];
int cas, last, qwe;
inline void prepare()
{
dp[0][0] = 1;
for(int i = 0; i <= 9; ++i) dp[1][i] = 1;
for(int i = 2; i < maxn; ++i)
for(int j = 0; j < 10; ++j)
for(int k = 0; k <= 15; ++k)
dp[i][j ^ k] += dp[i - 1][k], dp[i][j ^ k] %= mod;
}
inline int workk(char * str)
{
int len = strlen(str + 1); int pre = 0; int ret = 0;
memset(ans, 0, sizeof(ans));
for(int i = 1; i <= len; ++i)
{
int num = str[i] - '0';
for(int j = 0; j < num; ++j)
{
for(int k = 0; k <= 15; ++k)
{
ans[pre ^ j ^ k] += dp[len - i][k];
ans[pre ^ j ^ k] %= mod;
}
}
pre ^= num;
}
for(int i = 1; i <= 15; ++i) ret = (ret + (long long)i * ans[i]) % mod;
return ret;
}
int main()
{
prepare();
int t; scanf("%d", &t);
while(t--)
{
cas++; qwe = 0; last = 0;
scanf("%s", a + 1); scanf("%s", b + 1); int p = strlen(b + 1);
for (int i = 1; i <= p; i++) last ^= (b[i] - '0');
qwe = (workk(b) - workk(a) + mod) % mod;
qwe = (qwe + last) % mod;
printf("Case #%d: %d\n", cas, qwe);
}
return 0;
}
hdu 5435 A serious math problem的更多相关文章
- HDU 5055 Bob and math problem(结构体)
主题链接:http://acm.hdu.edu.cn/showproblem.php?pid=5055 Problem Description Recently, Bob has been think ...
- HDU 1757 A Simple Math Problem 【矩阵经典7 构造矩阵递推式】
任意门:http://acm.hdu.edu.cn/showproblem.php?pid=1757 A Simple Math Problem Time Limit: 3000/1000 MS (J ...
- hdu 1757 A Simple Math Problem (乘法矩阵)
A Simple Math Problem Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- HDU 5615 Jam's math problem
Jam's math problem Problem Description Jam has a math problem. He just learned factorization.He is t ...
- HDU 1757 A Simple Math Problem (矩阵快速幂)
题目 A Simple Math Problem 解析 矩阵快速幂模板题 构造矩阵 \[\begin{bmatrix}a_0&a_1&a_2&a_3&a_4&a ...
- HDU 1757 A Simple Math Problem(矩阵)
A Simple Math Problem [题目链接]A Simple Math Problem [题目类型]矩阵快速幂 &题解: 这是一个模板题,也算是入门了吧. 推荐一个博客:点这里 跟 ...
- HDU 1757 A Simple Math Problem (矩阵乘法)
A Simple Math Problem Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- hdu 5974 A Simple Math Problem
A Simple Math Problem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Ot ...
- HDU 1757 A Simple Math Problem(矩阵高速幂)
题目地址:HDU 1757 最终会构造矩阵了.事实上也不难,仅仅怪自己笨..= =! f(x) = a0 * f(x-1) + a1 * f(x-2) + a2 * f(x-3) + -- + a9 ...
随机推荐
- A Tutorial on Using the ALSA Audio API
A Tutorial on Using the ALSA Audio API This document attempts to provide an introduction to the ALSA ...
- windows10安装nodejs 10和express 4
最进做一个个人博客系统,前端用到了semanticUI,但是要使用npm工具包,所以需要安装nodejs,nodejs自带npm 下载 去官网下载自己系统对应的版本,我的是windows:下载 可以在 ...
- springboot打包成jar文件无法正常运行,解决办法已经找到
1.用intellij idea 创建了一个springboot的项目,前期都运行的好好的,在ide中可以正常运行,但是打包成Jar运行却一直报错. 2.经过不懈探索,终于找到解决办法 3.首先,找到 ...
- pychrome激活
http://blog.csdn.net/fx677588/article/details/58164902
- java 计算时间差
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); try { Date d1 = df.parse(&quo ...
- Celery与Django的结合
一.什么是Celery Celery 是一个 基于python开发的分布式异步消息任务队列,通过它可以实现任务的异步处理以及定时任务的处理,它的基本工作流程是: 先启动任务执行单元Worker,让它一 ...
- jmeter 参数化2_CSV Data Set Config
CSV Data Set Config:适用于参数取值范围较大的时候使用,该方法具有更大的灵活性 操作路径:HTTP取样器-->Add-->Config Element-->CSV ...
- hdu 3183 rmq+鸽巢原理
题目大意: 给你一个数字字符串序列,给你要求删掉的数字个数m,删掉m个数使的剩下的数字字符串的之最小.并输出这个数字: 基本思路; 这题解法有很多,贪心,rmq都可以,这里选择rmq,因为很久没有写r ...
- java 大数运算,高精度模板
转自:https://blog.csdn.net/stffer/article/details/46382949 有修改 关于BigInteger类更详细的用法请移步官方文档 package prac ...
- MVC模式设计的Web层框架初识
struts是个什么东西? struts是一个按MVC模式设计的Web层框架,其实它就是一个大大的servlet,这个Servlet名为ActionServlet,或是ActionServlet的子类 ...