题目链接

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的更多相关文章

  1. 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 ...

  2. HDU 2016.11.12 做题感想

    细数一下这两天做过的值得总结的一些题Orz...... HDU 2571 简单dp,但是一开始WA了一发.原因很简单:没有考虑仔细. 如果指向该点的所有点权值都为负数,那就错了(我一开始默认初始值为0 ...

  3. 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 ...

  4. 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) ...

  5. HDU 1425 sort hash+加速输入

    http://acm.hdu.edu.cn/showproblem.php?pid=1425 题目大意: 给你n个整数,请按从大到小的顺序输出其中前m大的数. 其中n和m都是位于[-500000,50 ...

  6. 2019DX#6

    Solved Pro.ID Title Ratio(Accepted / Submitted)   1001 Salty Fish 16.28%(7/43)  OK 1002 Nonsense Tim ...

  7. 2019 Multi-University Training Contest 6

    A.Salty Fish upsolved 题意 偷苹果,每个节点上有\(a[i]\)个苹果,在某些位置有摄像机,看管子树里距离不超过\(k[i]\)的节点,损坏摄像机有\(c[i]\)代价,求最大收 ...

  8. 地区sql

    /*Navicat MySQL Data Transfer Source Server : localhostSource Server Version : 50136Source Host : lo ...

  9. (能被11整除的数的特征)The shortest problem --hdu

    链接: http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1005&cid=595 若一个整数的个位数字截去,再从余下的数中 ...

随机推荐

  1. python语言快捷注释

    1.注释单行 (1)方法1:直接在单行代码前边加 # (2)方法2:选中需要注释的代码,Ctrl+/ 即可注释 2.注释多行代码 选中想要注释的N行代码,直接Ctrl+/ 即可注释 3.取消注释多行代 ...

  2. 1.4.3 ID遍历爬虫(每天一更)

    # -*- coding: utf-8 -*- ''' Created on 2019年5月7日 @author: 薛卫卫 ''' import itertools import urllib.req ...

  3. 【Sublime】设置显示编码格式

    Mac 上的 Sublime 显示编码格式,设置方法: 右下角显示的 UTF-8 就是当前的编码格式. 添加如下代码: { "font_size": 18, // Display ...

  4. Restful API 中的错误处理

    简介 随着移动开发和前端开发的崛起,越来越多的 Web 后端应用都倾向于实现 Restful API. Restful API 是一个简单易用的前后端分离方案,它只需要对客户端请求进行处理,然后返回结 ...

  5. Oracle_InstantClient 及PL/SQL Developer工具的安装

    一.下载 InstantClient 地址: http://www.oracle.com/technology/software/tech/oci/instantclient/index.html i ...

  6. 01-Spring Security框架学习--入门(二)

    一.入门案例 Spring Security 自定义登录界面 通过之前的一节 01-Spring Security框架学习--入门(一)的简单演示,Spring security 使用框架自带的登录界 ...

  7. 观书有感(摘自12期CSDN)

    CSDN要闻 Visual Studio 将登陆Mac平台 在11月的Connect()上,微软正式发布了Visual Studio For Max预览版,这是微软这一编程工具首次进入苹果平台.Vis ...

  8. Spark 系列(十四)—— Spark Streaming 基本操作

    一.案例引入 这里先引入一个基本的案例来演示流的创建:获取指定端口上的数据并进行词频统计.项目依赖和代码实现如下: <dependency> <groupId>org.apac ...

  9. 再次学习Git版本控制工具

    Git 究竟是怎样的一个系统呢?为什么在SVN作为版本控制工具已经非常流行的时候,还有Git这样一个版本控制工具呢?Git和SVN的区别在哪儿呢?Git优势又在哪呢?下面PHP程序员雷雪松带你一起详细 ...

  10. ABAP_增强点查找

    *&---------------------------------------------------------------------* *& Report Z_FIND_EN ...