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 若一个整数的个位数字截去,再从余下的数中 ...
随机推荐
- Android 开发使用自定义字体
有时候,系统自带的字体并不能满足我们特殊的需求,这时候就需要引用其他的字体了,可以把下载的字体文件放在 assets 目录下. 自定义字体文件不能使用xml代码读取而应该使用java代码: publi ...
- Zookeeper 学习笔记(一)之功能介绍
Zookeeper 主要在以下场景中可以使用 一,命名服务(用到了zookeeper的文件系统) 命名服务是指通过指定的名字来获取资源或者服务的地址,利用zk创建一个全局的路径,提供服务的地址或者一个 ...
- 自定义SWT控件七之自定义Shell(可伸缩窗口)
7.可伸缩窗口 该自定义窗口可以通过鼠标随意更改窗口大小 package com.hikvision.encapsulate.view.control.shell; import org.eclips ...
- Python基础总结之认识lambda函数、map函数、filter() 函数。第十二天开始(新手可相互督促)
今天周日,白天在学习,晚上更新一些笔记,希望对大家能更好的理解.学习python~ lambda函数,也就是大家说的匿名函数.它没有具体的名称,也可以叫做一句话函数,我觉得也不过分,大家看下代码,来体 ...
- 基于JaCoCo的Android测试覆盖率统计(二)
> 本文章是我上一篇文章的升级版本,详见地址:https://www.cnblogs.com/xiaoluosun/p/7234606.html ## 为什么要做这个?1. 辛辛苦苦写了几百条测 ...
- 对Java中HashCode方法的深入思考
前言 最近在学习 Go 语言,Go 语言中有指针对象,一个指针变量指向了一个值的内存地址.学习过 C 语言的猿友应该都知道指针的概念.Go 语言语法与 C 相近,可以说是类 C 的编程语言,所以 Go ...
- webpack4 前端框架基础配置实例-解决css分离图片路径问题
1.安装nodejs 2. 需要全局和项目安装webpack和webpack-dev-server npm install webpack webpack-dev-server -g npm inst ...
- 《Java 8 in Action》Chapter 1:为什么要关心Java 8
自1998年 JDK 1.0(Java 1.0) 发布以来,Java 已经受到了学生.项目经理和程序员等一大批活跃用户的欢迎.这一语言极富活力,不断被用在大大小小的项目里.从 Java 1.1(199 ...
- JVM调优实战:G1中的to-space exhausted问题
最近刚刚将自己的一个应用从CMS升级到G1,在一天早上,刚刚到办公室坐下,就收到手机一阵报警,去查看了监控,发现机器的内存出现了一个90度的涨幅,如下图所示: 在查看GC日志后,发现那个时间点附近出现 ...
- Java内部类的基本解析
内部类 内部类的基本概念 所谓的内部类也就是在一个类的内部进行其他类结构的嵌套操作. 为什么要使用内部类? 这就要引用一句十分著名的一本书叫<Think in java>中的一句名言了—— ...