【解题思路】

  状压DP。f[i][j][k]表示当前DP到第i位,模d意义下余数为j,状态为k的方案数。其中状态k表示每个数字还剩多少个没取,状态数最多210

  于是有递推式转移方程:f[i+1][(j+c)%d][k']+=f[i][j][k](c∈[0,9],k'为k删去数字c后的状态)。复杂度o(10T|s|d2|s|)。

【参考代码】

 #include <bits/stdc++.h>
#define range(i,c,o) for(register int i=(c);i<(o);++i)
#define dange(i,c,o) for(register int i=(c);i>(o);--i)
using namespace std; //#define __debug
#ifdef __debug
#define Function(type) type
#define Procedure void
#else
#define Function(type) __attribute__((optimize("-O2"))) inline type
#define Procedure __attribute__((optimize("-O2"))) inline void
#endif int cnt[],tmp[];
Function(int) status()
{
int ret=;
range(i,,) (ret*=cnt[i]+)+=tmp[i];
return ret;
} static int T,n,AwD; int f[][][];
int DFS(const int&k,const int&r)
{
if(k==n) return !r; int S=status();
if(~f[k][r][S]) return f[k][r][S];
f[k][r][S]=;
range(i,,) if(tmp[i])
{
--tmp[i];
f[k][r][S]+=DFS(k+,(r*+i)%AwD);
++tmp[i];
}
return f[k][r][S];
} char s[];
int main()
{
for(scanf("%d",&T);T--;)
{
scanf("%s%d",s,&AwD),n=strlen(s);
memset(cnt,,sizeof cnt);
range(i,,n) ++cnt[s[i]-''];
memcpy(tmp,cnt,sizeof tmp);
memset(f,-,sizeof f);
printf("%d\n",DFS(,));
}
return ;
}

最新文章

  1. jmobile学习之路 ----设备检测
  2. try-catch-finally 引发的奇怪问题
  3. clang -rewrite-objc的使用点滴
  4. USACO八皇后
  5. cookie与localstorage和sessionstorage的区别比较
  6. jqmobi 的一些設置
  7. 一个介绍webrtc的国外网址
  8. kettle Add XML 、 XML Join
  9. 建立dblink,clob
  10. 普通项目如何转换成Maven项目 --转载自百度知道
  11. 使用ip开头的工具,而不是只会ifconfig
  12. 正则求解@&quot; (?&lt;=^\[length=)(\d+)(?=\])&quot;
  13. C# string 保留数字英文字母
  14. python学习第2天
  15. Hyper-V 与 VMware 和 vbox 的不兼容
  16. hdu 2544 最短路(两点间最短路径)
  17. android之滑屏的实现
  18. POJ 2245
  19. JS开启浏览器全屏模式,需要手动触发
  20. odoo发送信息到微信公众平台、企业微信

热门文章

  1. xshell 挪动文件夹
  2. jsp中$使用不了
  3. 微信jssdk安卓机分享QQ好友和QQ空间出现{&quot;errMsg&quot;:&quot;shareQQ:fail&quot;}
  4. 在Delphi中使用系统对应文件类型的图标
  5. RzPageControl(pagecontrol)
  6. jquery+javascript触发a标签的点击事件
  7. PIL库,图像处理第三方库
  8. Python基础-main
  9. Redis 单机模式,主从模式,哨兵模式(sentinel),集群模式(cluster),第三方模式优缺点分析
  10. 解决oracle v$sqlarea sql不完整