题意:

给出\(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 + 枚举的更多相关文章

  1. [Luogu P3959] 宝藏 (状压DP+枚举子集)

    题面 传送门:https://www.luogu.org/problemnew/show/P3959 Solution 这道题的是一道很巧妙的状压DP题. 首先,看到数据范围,应该状压DP没错了. 根 ...

  2. HDU 6149 Valley Numer II 状压DP

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6149 题意:中文题目 解法:状压DP,dp[i][j]代表前i个低点,当前高点状态为j的方案数,然后枚 ...

  3. HDU 1074 Doing Homework【状压DP】

    Doing Homework Problem Description Ignatius has just come back school from the 30th ACM/ICPC. Now he ...

  4. HDU 5434 Peace small elephant 状压dp+矩阵快速幂

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5434 Peace small elephant  Accepts: 38  Submissions: ...

  5. HDU 1074 Doing Homework(状压DP)

    第一次写博客ORZ…… http://acm.split.hdu.edu.cn/showproblem.php?pid=1074 http://acm.hdu.edu.cn/showproblem.p ...

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

  7. HDU 4906 Our happy ending (状压DP)

    HDU 4906 Our happy ending pid=4906" style="">题目链接 题意:给定n个数字,每一个数字能够是0-l,要选当中一些数字.然 ...

  8. HDU 1074 Doing Homework (状压dp)

    题意:给你N(<=15)个作业,每个作业有最晚提交时间与需要做的时间,每次只能做一个作业,每个作业超出最晚提交时间一天扣一分 求出扣的最小分数,并输出做作业的顺序.如果有多个最小分数一样的话,则 ...

  9. HDU 4568 Hunter 最短路+状压DP

    题意:给一个n*m的格子,格子中有一些数,如果是正整数则为到此格子的花费,如果为-1表示此格子不可到,现在给k个宝藏的地点(k<=13),求一个人从边界外一点进入整个棋盘,然后拿走所有能拿走的宝 ...

随机推荐

  1. KBEngine warring项目源码阅读(一) 项目简介和注册

    首先介绍下warring项目,是kbe自带的一个演示示例,大部分人了解kbe引擎也是从warring项目开始的. 项目地址:https://github.com/kbengine/kbengine_u ...

  2. 数据库(DBUtils)

    DBUtils和连接池 今日内容介绍 u DBUtils u 连接池 第1章 DBUtils 如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC开发,本案例我们讲采用apache c ...

  3. Android 悬浮窗权限各机型各系统适配大全

    这篇博客主要介绍的是 Android 主流各种机型和各种版本的悬浮窗权限适配,但是由于碎片化的问题,所以在适配方面也无法做到完全的主流机型适配,这个需要大家的一起努力,这个博客的名字永远都是一个将来时 ...

  4. Kyligence Analytics Platform Enterprise

    平台: arm 类型: ARM 模板 软件包: kap 2.3 kyanalyzer 2.3 apache kylin basic software bi big data cube data war ...

  5. Flexbox与Grid属性比较

    网格容器(container)属性 网格项目(item)属性 Flex容器(container)属性 Flex项目(item)属性

  6. springMvc-对servletApi的支持以及把后台对象以json方式传到前台

    1.对servletApi的支持:request.response以及session.cookie的支持 2.把后台代码以json格式向前台输出: 代码: package com.java.contr ...

  7. SQL Server 删除当前数据库中所有数据库 ,无视约束

    Sql Server中清空所有数据表中的记录 清空所有数据表中的记录: exec sp_msforeachtable  @Command1 ='truncate table ?' 删除所有数据表: e ...

  8. IOS enum(枚举)使用

    typedef enum { MJMessageTypeMe=, MJMessageTypeOther }MJMessageType; /** *信息的类型 * */ @property (nonat ...

  9. solr数据分片相关

    solr操作url 使用正常的core,使用命令生成coillection solr create_collection -c students2 -d ../server/solr/my/conf ...

  10. Cesium专栏-测量工具测距、测面、测高(附源码下载)

    Cesium Cesium 是一款面向三维地球和地图的,世界级的JavaScript开源产品.它提供了基于JavaScript语言的开发包,方便用户快速搭建一款零插件的虚拟地球Web应用,并在性能,精 ...