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 若一个整数的个位数字截去,再从余下的数中 ...
随机推荐
- 定时延时设计FPGA
以50MHZ时钟为例,进行1秒钟延时,并输出延时使能信号. 首先计算需要多少次计时,MHZ=10的六次方HZ.T=20ns 一秒钟需要计时次数为5的七次方即5000_0000. 然后计算需要几位的寄存 ...
- 记录用友T+接口对接的心酸历程
前言:公司的业务主要是对接财务系统做单据传输或者凭证处理的,难免少不了和各大财务软件做数据对接,其中当然是必须通过接口来传递数据了.于是乎,用友T+的版本来了,对接的工作自然是我来做,可没想到就是这样 ...
- HiveQL DDL 常用QL示例资料
hive-version2.1.1 DDL操作 Create/Drop/Alter/Use Database 创建数据库 //官方指导 CREATE (DATABASE|SCHEMA) [IF NOT ...
- .netcore持续集成测试篇之Xunit结合netcore内存服务器发送post请求
系列目录 Web项目中,很多与用户数据交互的请求都是Post请求,想必大家都用过HttpClient构造过post请求,这里并不对HttpClient做详细介绍,只介绍一些常用的功能.并结合AutoF ...
- c#引用本地dll发布后运行exe错误
在config 文件夹 configuration 配置节点下面 添加 <runtime> <gcConcurrent enabled="true" /> ...
- 在linux系统下安装mysql详解,以及远程调用连接不上mysql的解决方法。
步骤: 1)查看CentOS自带的mysql 输入 rpm -qa | grep mysql 2)将自带的mysql卸载 3)上传Mysql的安装包到linux 4)安装mysql的依赖(不是必须) ...
- jenkins无法连接到git原因
1.账号密码错误 2.公钥私钥不对应(git上为公钥,jenkins为私钥,私钥比公钥长) 3.公钥私钥文件没有复制到jenkins目录下的.ssh文件中
- 建立apk定时自动打包系统第一篇——Ant多渠道打包并指定打包目录和打包日期
团队开发时,每天都需要输出一个apk包给其它部门的同事测试验证.打包几乎是每天必须完成的功课.如果用IDE来输出apk,那速度是非常慢的,如果还需要有不同渠道的apk包,那程序猿都要疯了.当然也有用 ...
- 浏览器DOM渲染及阻塞问题
在准备面试,然后复习到了计网的知识点,紧接着又扯到了url从输入到浏览器渲染的那个问题,这里来顺便完善补充一下,本文的重点在渲染 上面的图就是浏览器从服务器请求来页面后渲染的全过程 这里我们分开来看: ...
- Linux 终端命令格式
Linux 终端命令格式 一.目标 了解终端命令格式 知道如何查阅终端命令帮助信息 二. 终端命令格式 command [-options] [parameter] 说明: command:命令名,相 ...