hdu-6644 11 Dimensions
题目链接
Problem Description
11 Dimensions is a cute contestant being talented in math. One day, 11 Dimensions came across a problem but didn't manage to solve it. Today you are taking training here, so 11 Dimensions turns to you for help.
You are given a decimal integer S with n bits s1s2…sn(0≤si≤9), but some bits can not be recognized now(replaced by "?''). The only thing you know is that Sis a multiple of a given integer m.
There may be many possible values of the original S, please write a program to find the k-th smallest value among them. Note that you need to answer q queries efficiently.
Input
The first line of the input contains an integer T(1≤T≤10000), denoting the number of test cases.
In each test case, there are three integers n,m,q(1≤n≤50000,2≤m≤20,1≤q≤100000) in the first line, denoting the length of S, the parameter m, and the number of queries.
In the second line, there is a string s of length n, denoting the given decimal integer S. It is guaranteed that si is either an integer within [0,9] or ``?'', and s1 is always an integer within [1,9].
For the next q lines, each line contains an integer ki(1≤ki≤1018), denoting each query.
It is guaranteed that ∑n≤500000 and ∑q≤10^6.
Output
For each query, print a single line containing an integer, denoting the value of S. If the answer exists, print Smod(10^9+7) instead, otherwise print ``-1''.
Sample Input
1
5 5 5
2??3?
1
2
3
100
10000
Sample Output
20030
20035
20130
24935
-1
题意
给一个长度为n的数字,某些位丢失变成了'?',让你给这些问号填上数字,使得整个数字是m的倍数,且是所有方案中第K小的方案,最后输出整个数字取模1e9+7
题解
对于一个数字\(123??21?\)可以拆成两部分\(12300210\)和\(??00?\),先把\(12300210\)对m取模,假设结果为a,那么要让原数字整除m,问题就变成使 \(??00? \mod m = m-a\)
设\(dp[i][j]\)表示倒数i个问号已经填好,取模m结果为j的方案数,输出答案时只要逐位枚举?就行了,但是查询量太大,问号个数也很大,逐位枚举会超时,实际上只要枚举最后二三十个问号,前面的问号全部填0,因为b个问号可以填的方案数是\(10^b\),假设这\(10^b\)个方案数取模m的结果是均匀的,也就是说取模m为\([1,m-1]\)的方案数大致都在\(\frac{10^b}{m}\)左右,k只有\(10^{18},m只有20\),b取30就肯定足以把结果涵盖进去了。
代码
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mx = 50005;
const int mod = 1e9+7;
const ll INF = 1LL<<61;
char str[mx];
int pos[mx];
ll dp[mx][20];
ll pm[mx], pmod[mx];
int pow_mod(ll a, ll b, ll c) {
ll ans = 1;
while (b > 0) {
if (b & 1) ans = ans * a % c;
a = a * a % c;
b /= 2;
}
return ans;
}
int main() {
int T;
scanf("%d", &T);
while(T--) {
int n, m, q, cnt = 0;
scanf("%d%d%d", &n, &m, &q);
scanf("%s", str+1);
int len = std::strlen(str+1);
int ans_mod = 0;
ll ans = 0;
for (int i = 1; i <= len; i++) {
ans_mod = ans_mod * 10;
ans = ans * 10;
if (str[i] != '?') {
ans_mod = ans_mod + (str[i] - '0');
ans = ans + (str[i] - '0');
}
ans_mod %= m;
ans %= mod;
}
for (int i = len; i >= 1; i--)
if (str[i] == '?') pos[++cnt] = len-i;
for (int i = 1; i <= cnt; i++) {
pm[i] = pow_mod(10, pos[i], m);
pmod[i] = pow_mod(10, pos[i], mod);
}
ans_mod = (m-ans_mod) % m;
for (int i = 1; i <= cnt; i++) memset(dp[i], 0, sizeof(dp[i]));
dp[0][0] = 1;
for (int i = 1; i <= cnt; i++) {
for (int j = 0; j <= 9; j++) {
int tmp = j * pm[i] % m;
for (int k = 0; k < m; k++) {
dp[i][(tmp+k)%m] += dp[i-1][k];
if (dp[i][(tmp+k)%m] > INF) dp[i][(tmp+k)%m] = INF;
}
}
}
ll tmp = ans;
while (q--) {
ll k;
scanf("%lld", &k);
if (dp[cnt][ans_mod] < k) {
puts("-1");
continue;
}
int now_mod = ans_mod, next_mod;
ans = tmp;
for (int i = min(cnt, 30); i >= 1; i--) {
for (int j = 0; j <= 9; j++) {
int next_mod = (now_mod - (j*pm[i]%m) + m) % m;
if (dp[i-1][next_mod] < k) {
k -= dp[i-1][next_mod];
} else {
ans += j * pmod[i] % mod;
ans %= mod;
now_mod = next_mod;
break;
}
}
}
printf("%lld\n", ans % mod);
}
}
return 0;
}
hdu-6644 11 Dimensions的更多相关文章
- Fibonacci Again 分类: HDU 2015-06-26 11:05 13人阅读 评论(0) 收藏
Fibonacci Again Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Tot ...
- HDU 2016.11.12 做题感想
细数一下这两天做过的值得总结的一些题Orz...... HDU 2571 简单dp,但是一开始WA了一发.原因很简单:没有考虑仔细. 如果指向该点的所有点权值都为负数,那就错了(我一开始默认初始值为0 ...
- Design T-Shirt 分类: HDU 2015-06-26 11:58 7人阅读 评论(0) 收藏
Design T-Shirt Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) T ...
- Train Problem I 分类: HDU 2015-06-26 11:27 10人阅读 评论(0) 收藏
Train Problem I Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDU 1425 sort hash+加速输入
http://acm.hdu.edu.cn/showproblem.php?pid=1425 题目大意: 给你n个整数,请按从大到小的顺序输出其中前m大的数. 其中n和m都是位于[-500000,50 ...
- 2019DX#6
Solved Pro.ID Title Ratio(Accepted / Submitted) 1001 Salty Fish 16.28%(7/43) OK 1002 Nonsense Tim ...
- 2019 Multi-University Training Contest 6
A.Salty Fish upsolved 题意 偷苹果,每个节点上有\(a[i]\)个苹果,在某些位置有摄像机,看管子树里距离不超过\(k[i]\)的节点,损坏摄像机有\(c[i]\)代价,求最大收 ...
- 地区sql
/*Navicat MySQL Data Transfer Source Server : localhostSource Server Version : 50136Source Host : lo ...
- (能被11整除的数的特征)The shortest problem --hdu
链接: http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1005&cid=595 若一个整数的个位数字截去,再从余下的数中 ...
随机推荐
- Java入门 面向对象第一天
面向对象 人为抽象的一种编程模型,在理解面向对象的代码时要按照抽象的模型来理解,不能只从代码字面来理解复杂的问题,学会拆分成一个一个独立的小问题,通过解决每一个小问题,最后解决一个大问题 类 类是事物 ...
- chapter02 - 03
1.分别用cat \tac\nl三个命令查看文件/etc/ssh/sshd_config文件中的内容,并用自己的话总计出这三个文档操作命令的不同之处? 答:cat /etc/ssh/sshd_conf ...
- Charles PC端和手机端抓取HTTP和HTTPS协议请求、HTTPS通用抓包规则
一:HTTP和HTTPS的区别 HTTP是超文本传输协议,被用在Web浏览器和网站服务器之间传递信息,HTTP协议以明文方式发送内容,不提供任何方式的数据加密,因此HTTP协议不适合传输一些敏感信息, ...
- 关于定时器Scheduled(cron)的问题
定时器配置步骤参考:http://blog.csdn.NET/sd4000784/article/details/7745947 下面给出cron参数中各个参数的含义: CRON表达式 含义 & ...
- codeforces 327 A Ciel and Dancing
题目链接 给你一串只有0和1的数字,然后对某一区间的数翻转1次(0变1 1变0),只翻转一次而且不能不翻转,然后让你计算最多可能出现多少个1. 这里要注意很多细节 比如全为1,要求必须翻转,这时候我们 ...
- 【Spring源码解析】—— 委派模式的理解和使用
一.什么是委派模式 委派模式,是指什么呢?从字面含义理解,委派就是委托安排的意思,委派模式就是在做具体某件事情的过程中,交给其他人来做,这个事件就是在我的完整链路上的一部分,但是复杂度较高的情况下或者 ...
- c语言指针汇总
1.指向单个变量的指针: ; int* p = &a; printf("%d", *p); 2.数组的指针 (1)一维数组的指针 ] = { ,,,, }; int *p; ...
- OOM和JVM配置优化
OOM这个缩写就是Java程序开发过程中让人最头痛的问题:Out of Memory.在很多开发人员的开发过程中,或多或少的都会遇到这类问题,这类问题定位比较困难,往往需要根据经验来判断可能出现问题的 ...
- JavaSE之——并没有多维数组
近日在读<疯狂Java讲义>精粹第二版,部分语述摘自其中,自己边敲边理解 前言 我们知道,Java语言支持的类型有两种: 1.基本类型(即八大基本数据类 ...
- Spring Boot 修改静态资源一定要重启项目才会生效吗?未必!
回顾热部署 Spring Boot 中的热部署相信大家都用过吧,只需要添加 spring-boot-devtools 依赖就可以轻松实现热部署.Spring Boot 中热部署最最关键的原理就是两个不 ...