题目传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=5302

对于一个物品,设它体积为v,那么,在背包参数为p的情况下,它能达到gcd(v,p)的倍数的重量

对于两个物品,设它们的体积为v1和v2,那么,在背包参数为p的情况下,他能达到gcd(v1,v2,p)的倍数的重量

对于每个物品,我们记下它的gcd(v,p),问题变为给定一个x,求有多少个v的集合,是集合内所有元素的gcd能被x整除

我们设dp[i][j]表示p的前i个约数有多少种组合是组合后的gcd为j。

接下来,我们考虑怎么转移

先给伪代码(不加取模):

for(i=1;i<=约数个数;++i)

  for(j=1;j<=约数个数;++j){

    x=gcd(第i个约数,第j个约数)dp[i][x]+=dp[i-1][j]*(2^约数i的个数-1);

    dp[i][j]+=dp[i][j-1];

  }

这种转移方式有点奇怪,是个好思路,我们平常的dp都是枚举状态,然后在寻找能转移到我们枚举的状态的状态。这个dp是先枚举已经计算完成的状态,在计算这些状态能转移到哪,更新,有点类似noip2017 提高组day1T3的拓扑排序dp写法。

上AC代码(wxy数组就是dp数组,有些细节上的处理我还没讲,可以自己实现,ps:我常数有点大(两个map)):

#include <bits/stdc++.h>
using namespace std;
;
;
#define _l long long
int n,q,p,ys[N];
map<int,int>reff;
map<int,int>cnt;
_l p2[N*N],wxy[N][N],an[N];
 ? y:gcd(y,x%y);}
int main(){
    scanf("%d%d%d",&n,&q,&p);
    int i;
    ;i*i<=p;++i)){
        ys[++ys[]]=i,reff[i]=ys[];]]=p/i,reff[p/i]=ys[];
    }
    ;i<=n;++i){
        int x;scanf("%d",&x);x=gcd(max(x,p),min(x,p));
        ++cnt[x];
    }
    ]=;
    ;i<=n;++i)p2[i]=(p2[i-]*)%md;wxy[][reff[p]]=;
    ;i<=ys[];++i);j<=ys[];++j){
        int tmp=gcd(max(ys[i],ys[j]),min(ys[i],ys[j]));
        wxy[i][reff[tmp]]=(wxy[i][reff[tmp]]+wxy[i-][j]*(_l)(p2[cnt[ys[i]]]-))%md;
        wxy[i][j]=(wxy[i-][j]+wxy[i][j])%md;
    }
    ;i<=ys[];++i);j<=ys[];++j))an[i]=(an[i]+wxy[ys[]][j])%md;
    while(q--){
        int x;scanf("%d",&x);x=gcd(max(x,p),min(x,p));
        printf("%lld\n",an[reff[x]]);
    }
}

最新文章

  1. RESTful Api 身份认证安全性设计
  2. eclipse 导入工程报错Unable to execute dex: Multiple dex files define Landroid/annotation/SuppressLint
  3. 在windows平臺下使用cygwin獲取root用戶權限
  4. QRCode二维码生成
  5. 全息眼镜HoloLens可快速捕捉真人3D图像
  6. .net中对象序列化技术浅谈
  7. html移动开发app-framework2.0使用心得
  8. 【转】jsp页面中jstl标签详解
  9. CodeForces 534B Covered Path (水题)
  10. linux常用命令详解
  11. lemon OA 下阶段工作安排
  12. CSS3旋转图片效果收集
  13. Effective JavaScript :第二章
  14. java编程基础复习-------第二章
  15. Python爬虫-尝试使用人工和OCR处理验证码模拟登入
  16. Spring容器AOP的实现原理——动态代理(转)
  17. Vue.js最佳实践
  18. .NET开源了,Visual Studio开始支持 Android 和 iOS 编程并自带Android模拟器
  19. 如何从ie11降到ie9
  20. DataAnnotations 验证

热门文章

  1. 【VisualStudio】软件安装中出现的问题
  2. 对存在JavaScript隐式类型转换的四种情况的总结
  3. SLF4j+LOG4j
  4. 【转】 Pro Android学习笔记(六二):Preferences(6):header
  5. ES6学习之Generator函数
  6. C# 删除文件和目录到回收站
  7. VIsual Studio 2010 常用快捷键
  8. union联合体学习
  9. Matlab零碎知识
  10. top查看CPU情况