HDU 5657 CA Loves Math 状压DP + 枚举
题意:
给出\(A(2 \leq A \leq 11), n(0 \leq n \leq 10^9), k(1 \leq k \leq 10^9)\)。
求区间\([1, A^n]\)中各个数字互不相同的\(A\)进制数而且是\(k\)的倍数的个数。
分析:
如果\(n > A\),根据抽屉原理,\(n\)位\(A\)进制数一定会有重复的数字。
所以下面只讨论\(n \leq a\)的情况。
对于\(k\)的大小,分别使用不同的算法:
\(k\)比较小的时候,用状压DP:\(d(S, x)\)表示当前数字集合为\(S\)且模\(k\)为\(x\)的数字的个数。
在数字的末位添加一个未在集合\(S\)出现的数字\(i\),则转移到状态\(d(S',(x \cdot A + i) % k)\)。\(k\)比较大的时候,直接暴力统计。枚举区间内所有\(k\)的倍数,判断一下如果没有重复数字答案+1。
第一种算法的复杂度为\(O(2^A \cdot k \cdot A)\),状态数乘转移数。
第二种算法复杂度为\(O(A^n/k \cdot A)\),枚举次数乘判断时间。
找到一个合适的边界使得时限都能承受两种算法,测试了一下\(25000\)和\(30000\),运行时间都是\(3s\)多,可以AC。
PS:\(n=0\)和\(n=1\)这些边界情况最好特判一下。
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long LL;
int A, n, k;
const int maxk = 30000;
const int maxa = 11;
LL d[1 << maxa][maxk];
int bitcount(int x) {
int ans = 0;
while(x) { if(x & 1) ans++; x >>= 1; }
return ans;
}
bool check(LL x) {
int S = 0;
while(x) {
int t = x % A;
x /= A;
if(S & (1 << t)) return false;
S |= (1 << t);
}
return true;
}
int main()
{
int T; scanf("%d", &T);
while(T--) {
scanf("%d%d%d", &A, &n, &k);
if(n == 0) {
if(k == 1) printf("1\n");
else printf("0\n");
continue;
}
if(n == 1) {
printf("%d\n", A / k);
continue;
}
//DP
if(k < maxk) {
memset(d, 0, sizeof(d));
for(int i = 1; i < A; i++) d[1 << i][i % k] = 1;
for(int S = 0; S < (1 << A); S++) if(bitcount(S) < n) {
for(int x = 0; x < k; x++) if(d[S][x]) {
for(int i = 0; i < A; i++) if(!(S&(1<<i))) {
d[S|(1<<i)][(x*A+i)%k] += d[S][x];
}
}
}
LL ans = 0;
for(int S = 0; S < (1 << A); S++)
if(d[S][0]) ans += d[S][0];
printf("%lld\n", ans);
} else {
if(n > A) n = A;
LL An = 1; //A^n
for(int i = 1; i <= n; i++) An *= A;
LL ans = 0;
for(LL t = k; t <= An; t += k)
if(check(t)) ans++;
printf("%lld\n", ans);
}
}
return 0;
}
HDU 5657 CA Loves Math 状压DP + 枚举的更多相关文章
- [Luogu P3959] 宝藏 (状压DP+枚举子集)
题面 传送门:https://www.luogu.org/problemnew/show/P3959 Solution 这道题的是一道很巧妙的状压DP题. 首先,看到数据范围,应该状压DP没错了. 根 ...
- HDU 6149 Valley Numer II 状压DP
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6149 题意:中文题目 解法:状压DP,dp[i][j]代表前i个低点,当前高点状态为j的方案数,然后枚 ...
- HDU 1074 Doing Homework【状压DP】
Doing Homework Problem Description Ignatius has just come back school from the 30th ACM/ICPC. Now he ...
- HDU 5434 Peace small elephant 状压dp+矩阵快速幂
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5434 Peace small elephant Accepts: 38 Submissions: ...
- HDU 1074 Doing Homework(状压DP)
第一次写博客ORZ…… http://acm.split.hdu.edu.cn/showproblem.php?pid=1074 http://acm.hdu.edu.cn/showproblem.p ...
- HDU - 4284 Travel(floyd+状压dp)
Travel PP loves travel. Her dream is to travel around country A which consists of N cities and M roa ...
- HDU 4906 Our happy ending (状压DP)
HDU 4906 Our happy ending pid=4906" style="">题目链接 题意:给定n个数字,每一个数字能够是0-l,要选当中一些数字.然 ...
- HDU 1074 Doing Homework (状压dp)
题意:给你N(<=15)个作业,每个作业有最晚提交时间与需要做的时间,每次只能做一个作业,每个作业超出最晚提交时间一天扣一分 求出扣的最小分数,并输出做作业的顺序.如果有多个最小分数一样的话,则 ...
- HDU 4568 Hunter 最短路+状压DP
题意:给一个n*m的格子,格子中有一些数,如果是正整数则为到此格子的花费,如果为-1表示此格子不可到,现在给k个宝藏的地点(k<=13),求一个人从边界外一点进入整个棋盘,然后拿走所有能拿走的宝 ...
随机推荐
- C 碎片四 流程控制
前面介绍了程序中用到的一些基本要素(常量,变量,运算符,表达式),他们是构成程序的基本成分,下面将介绍C语言中流程控制的三种结构:顺序结构.分支结构.循环结构 一.顺序结构 顺序结构的程序设计是最简单 ...
- ubuntu下编译安装mysql记录
搞了整整一天,好不容易折腾完,在此记录下,下次就省事了. 去官网http://www.php.net/downloads.php下载所需要的php版本,这里我选择5.6.22. ...
- MobaXterm连接远程Linux服务器
MobaXterm是一个X服务器和一组的Unix命令(GNU/ Cygwin的)封装在一个单一的便携式exe文件的增强终端. MobaXterm包括一个巨大的multitab原生的Windows终端. ...
- C#利用WebClient 两种方式下载文件(一)
WebClient client = new WebClient(); 第一种 string URLAddress = @"http://files.cnblogs.com/x4646/tr ...
- C#开发android应用实战 源码
原书名: Professional Android Programming with Mono for Android and .NET/C# Download Title Size Down ...
- zabbix-3.4 触发器
3 触发器 概述 触发器是"评估"由项目采集的数据并表示当前系统状况的逻辑表达式. 当监控项用于采集系统的数据时,始终遵循这些数据是非常不切合实际的,因为这些数据始终在等待一个令人 ...
- newCoder在线编程---(1)
二维数组查找 题目描述: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 1.暴 ...
- HDU 1008 电梯( 水题)
题意: 电梯当前在0层,每在1层需要停5秒,往上走每层需6秒,往下走每层需要4秒. 思路: 在接收输入的时候直接计算了它,不用再弄一个循环.每计算一个请求就更新当前层,停留5秒的等到输出时再加上5*n ...
- 使用SAP云平台的destination消费Internet上的OData service
通过SAP云平台上的destination我们可以消费Internet上的OData service或者其他通过HTTP方式暴露出来的服务. 创建一个新的destination: 维护如下属性: 点击 ...
- 小记:iOS 中一般对于 view 不依赖 model 的的两种代码书写形式
一. 前言 对于在 MVC 的定义中,view 层是不引用 model 层,view 和 model 是不相往来的 一般开发中,我们都写过 在自定义 view 中增加一个 model 的属性,外接直接 ...