BZOJ1172 : [Balkan2007]Dream

BZOJ1172 : [Balkan2007]Dream

$\gcd(ab,k)=\gcd(\gcd(a,k)\times \gcd(b,k),k)$

设$f[i][j]$表示前$i$行,与$k$的$\gcd$为$j$的方案数,$h[i]$表示当前行选一个或两个,乘积与$k$的$\gcd$为$i$的方案数,然后DP即可。

时间复杂度$O(N(M+K))$。

 

#include<cstdio>
#define N 165
typedef long long ll;
int n,m,K,L,i,j,k,d,a[N],id[200005],g[N][N],c[N],h[N],f[205][N];
inline void read(int&a){char c;while(!(((c=getchar())>='0')&&(c<='9')));a=c-'0';while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';}
ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
inline void up(int&x,int y){x=(x+y)%L;}
int main(){
  read(n),read(m),read(K),read(L);
  for(i=1;i<=K;i++)if(K%i==0)a[++d]=i,id[i]=d;
  for(i=1;i<=d;i++)for(j=1;j<=d;j++)g[i][j]=id[gcd(1LL*a[i]*a[j],K)];
  for(f[0][1]=i=1;i<=n;i++){
    for(j=1;j<=d;j++)c[j]=h[j]=0;
    for(j=1;j<=m;j++)read(k),c[id[gcd(k,K)]]++;
    for(j=1;j<=d;j++)up(h[j],c[j]);
    if(i>1&&i<n){
      for(j=1;j<=d;j++)up(h[g[j][j]],c[j]*(c[j]-1));
      for(j=1;j<=d;j++)for(k=1;k<j;k++)up(h[g[j][k]],c[j]*c[k]*2);
    }
    for(j=1;j<=d;j++)for(k=1;k<=d;k++)up(f[i][g[j][k]],f[i-1][j]*h[k]);
  }
  return printf("%d",f[n][d]),0;
}

  

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109218.html原文链接:https://javaforall.net

(0)
上一篇 2021年9月11日 下午2:21
下一篇 2021年9月11日 下午2:21


相关推荐

  • Themleaf模板基础语法使用介绍

    Themleaf模板基础语法使用介绍Themleaf 模板基础语法使用介绍一 Thymeleaf 是什么 Thymeleaf 是一个模板引擎 主要用于编写动态页面 Thymeleaf 是 SpringBoot 官方所推荐使用的 二 Thymeleaf 的作用问题 动态页面技术已经有 JSP 为什么还要用 Thymeleaf 主要原因包括以下几点 使用模块引擎来编写动态页面 让开发人员无法在页面上编写 Java 代码 使得 java 代码和前端代码绝对的分离 SpringBoot 默认整合 Thymeleaf 不需要任何配置直接整合成功 打 jar 包发

    2026年3月26日
    2
  • C++后端开发学习路线及推荐学习时间

    C++后端开发学习路线及推荐学习时间先说一下实习面试的结果吧 本人申请岗位为 C 后端开发 通过面试的公司有 CVTE 搜狐 字节跳动 然后腾讯明天三面 准备去字节了 不要问我为啥去字节 钱多福利好

    2026年3月18日
    3
  • 把旧光驱改CD播放机的方法

    把旧光驱改CD播放机的方法  随着我们自己PC机各项配件的不断升级,或多或少都会淘汰下来一些旧配件。它们是否真的就只能躺在角落里睡大觉呢?能够最大限度利用上这些曾经为我们驰骋沙场,立下赫赫战功的战将吗?那么就要看我们自己是否足够勤劳了。下面我们就以PC机中比较容易更新换代的光驱为例,来看看怎么让它恢复第二春吧。  先天条件  通常来说,光驱“惨遭”淘汰的时候读盘能力已经很弱了,但机械上一般都没有损坏,特别是CD是完…

    2022年4月29日
    59
  • 三维地图下载,3D地图下载,谷歌地球三维地形图查看

    三维地图下载,3D地图下载,谷歌地球三维地形图查看3D地球依据高程数据等对地表进行渲染,实现地表的起伏,模拟出真实的三维场景,让你有如身临其境般的感觉。(注:Bigemap3D地球是一个三维地图浏览功能,是基于高程数据进行的实时渲染,无法进行下载标注等,如需三维城市、创建三维地图模型等,可通过右侧【联系我们】进行咨询。另:3D地球浏览城市时无3D效果)3D地球使用详解1、打开Bigemap地图下载器,点击左下角【3D】地图…

    2022年5月21日
    57
  • 情感的强度分类_情感量表

    情感的强度分类_情感量表一、SO-HowNet   情感倾向强度值计算公式为:其中,Pwords代表正面情感种子词语集合,Nwords代表负面种子词语集合。word1和word2相似度就是各概念之间相似度的最大值。计算两个义原相似度公式如下:其中,p1,p2为两个需要计算比较的义原,Depth(p)是义原层次体系中的深度,Spd

    2022年8月23日
    10
  • 实验七 香农编码_香农编码效率可以大于1吗

    实验七 香农编码_香农编码效率可以大于1吗一、实验目的编程,对某一离散无记忆信源实现香农编码,输出消息符号及其对应的码字。设离散无记忆信源,。二进制香农编码过程如下:1、将信源发出的N个消息符号按其概率的递减次序依次排列。2、按下式计算第i个消息的二进制代码组的码长,并取整。3、为了编成唯一可译码,首先计算第i个消息的累加概率4、将累加概率Pi(为小数)变成二进制数5、除去小数点,并根据码长li,取小数点后li位数作为第i个消息的码字。二、实验环境Dev三、实验过程:#include<stdio.h>

    2025年10月18日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号