题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1004

题意:三种颜色的扑克牌各有Sr,Sb,Sg张。给出m种置换。两种染色方案在某种置换下相同时认为是一种。有多少种不同的排列?

思路:利用Burnside引理计算的两个步骤:

(1)找出所有的置换,在这里我们很容易认为只有m种,其实是m+1种,不动置换也是一种。坑爹。。

(2)求出每种置换下不动点个数。也就是对于每一种置换,我们要找出在这种置换下哪些排列在置换后还是这样。那么首先我们求出这种置换的循环节,那么在同一个循环节下的必然全部是同一种颜色的才能保证置换后不变。比如现在三种花色的分别为2,3,4,

置换为:1,3,2,5,6,4,8,9,7,此时置换节为(1)(2,3)(4,5,6)(7,8,9)也就是(1)(2)(3)(3),那么问题转化成用1,2,3,3拼成2,3,4三个数的方案数。设dp[i][j][k]表示得到三种花色分别为i,j,k的方案数,我们设a[1]=1,a[2]=2,a[3]=3,a[4]=3(也就是循环节),那么dp(i,j,k)=sum(dp(i-a[x],j,k)+dp(i,j-a[x],k)+dp(i,j,k-a[x]))(1<=x<=4且a[x]之前未被使用过)。

int Sr,Sb,Sg,m,mod,a[N][N],n;

int C[N][N],p[N];

void init()
{
    int i,j;
    for(i=0;i<=60;i++)
    {
        C[i][0]=C[i][i]=1;
        for(j=1;j<i;j++) C[i][j]=(C[i-1][j-1]+C[i-1][j])%mod;
    }
    p[0]=1;
    for(i=1;i<=100;i++) p[i]=p[i-1]*i%mod;
}

int exGcd(int a,int b,int &x,int &y)
{
    if(!b)
    {
        x=1; y=0;
        return a;
    }
    int temp=exGcd(b,a%b,x,y);
    int t=x;
    x=y;
    y=t-a/b*y;
    return temp;
}

int get(int n)
{
    int x,y;
    exGcd(n,mod,x,y);
    return (x%mod+mod)%mod;
}

int A[N],Anum,dp[N][N][N],visit[N];

int DFS(int x,int y,int z)
{
    if(x==0&&y==0&&z==0) return 1;
    if(x<0||y<0||z<0) return 0;
    if(dp[x][y][z]!=-1) return dp[x][y][z];
    int ans=0,i;
    FOR1(i,Anum) if(!visit[i])
    {
        visit[i]=1;
        ans+=DFS(x-A[i],y,z)+DFS(x,y-A[i],z)+DFS(x,y,z-A[i]);
        ans%=mod;
        visit[i]=0;
    }
    return dp[x][y][z]=ans;
}

int cal(int a[])
{
    Anum=0;
    int h[N]={0},i,j;
    FOR1(i,n) if(!h[a[i]])
    {
        Anum++;
        j=a[i]; h[i]=1; A[Anum]=1;
        while(j!=i) h[j]=1,j=a[j],A[Anum]++;
    }
    clr(dp,-1); clr(visit,0);
    return DFS(Sr,Sb,Sg);
}

int main()
{
    RD(Sr,Sb,Sg); RD(m,mod); init();
    n=Sr+Sb+Sg;
    int i,j;
    FOR1(i,m) FOR1(j,n) RD(a[i][j]);
    int ans=0;
    FOR1(i,m) ans=(ans+cal(a[i]))%mod;
    ans+=p[n]*get(p[Sr])*get(p[Sb])%mod*get(p[Sg])%mod;
    ans=ans*get(m+1)%mod;
    PR(ans);
    return 0;
}

BZOJ 1004 Cards(Burnside引理+DP)的更多相关文章

  1. BZOJ 1004 Cards(Burnside引理+DP)

    因为有着色数的限制,故使用Burnside引理. 添加一个元置换(1,2,,,n)形成m+1种置换,对于每个置换求出循环节的个数, 每个循环节的长度. 则ans=sigma(f(i))/(m+1) % ...

  2. bzoj1004: [HNOI2008]Cards(burnside引理+DP)

    题目大意:3种颜色,每种染si个,有m个置换,求所有本质不同的染色方案数. 置换群的burnside引理,还有个Pólya过几天再看看... burnside引理:有m个置换k种颜色,所有本质不同的染 ...

  3. [BZOJ 1004] [HNOI2008] Cards 【Burnside引理 + DP】

    题目链接:BZOJ - 1004 题目分析 首先,几个定义和定理引理: 群:G是一个集合,*是定义在这个集合上的一个运算. 如果满足以下性质,那么(G, *)是一个群. 1)封闭性,对于任意 a, b ...

  4. [bzoj 1004][HNOI 2008]Cards(Burnside引理+DP)

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1004 分析: 1.确定方向:肯定是组合数学问题,不是Polya就是Burnside,然后题目上 ...

  5. BZOJ 1004 HNOI2008 Cards Burnside引理

    标题效果:特定n张卡m换人,编号寻求等价类 数据保证这m换人加上置换群置换后本身构成 BZOJ坑爹0.0 条件不那么重要出来尼玛怎么做 Burnside引理--昨晚为了做这题硬啃了一晚上白书0.0 都 ...

  6. bzoj 1004 burnside 引理+DP

    对于burnside引理需要枚举染色,这道题属于burnside的一种简单求解的方法,就是polya,我们可以使每一种置换中的循环节中的元素的颜色都相同,那么这样的话就可以直接DP了,我们可以将m个置 ...

  7. 【bzoj1004】[HNOI2008]Cards Burnside引理+背包dp

    题目描述 用三种颜色染一个长度为 $n=Sr+Sb+Sg$ 序列,要求三种颜色分别有 $Sr,Sb,Sg$ 个.给出 $m$ 个置换,保证这 $m$ 个置换和置换 ${1,2,3,...,n\choo ...

  8. BZOJ1004: [HNOI2008]Cards(Burnside引理 背包dp)

    Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4255  Solved: 2582[Submit][Status][Discuss] Descript ...

  9. bzoj 1004 Cards & poj 2409 Let it Bead —— 置换群

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1004 关于置换群:https://www.cnblogs.com/nietzsche-oie ...

随机推荐

  1. netlink---Linux下基于socket的内核和上层通信机制 (转)

    需要在linux网卡 驱动中加入一个自己的驱动,实现在内核态完成一些报文处理(这个过程可以实现一种零COPY的网络报文截获),对于复杂报文COPY下必要的数据交给用户 态来完成(因为过于复杂的报文消耗 ...

  2. ios开发--旋转、移动、缩放手势实例代码

    代码如下: // 添加所有的手势 - (void) addGestureRecognizerToView:(UIView *)view { // 旋转手势 UIRotationGestureRecog ...

  3. iOS应用的真机调试

    必须条件:99美元的帐号,没有这个就不用再往下看了. 首先,登录到http://developer.apple.com/devcenter/ios/index.action,如果已经购买了iPhone ...

  4. mac os快捷键

    选中一个词,使用control+command+d,可以启用词典 option+command+d,隐藏/显示 doc command + k terminal 清除历史记录 control + up ...

  5. ubuntu14.04 安装matlab r2013a

    神奇的linux. 进入主题:matlab相信是不少工程人员缺少不了的工具,就我所在的通信行业更是如此,matlab的linux版本是和windows版本同步更新, 不过r2012之后只提供64位版本 ...

  6. easyui toolbar 可以放在datagrid底下

    html: <div class="easyui-tabs" style="height: 250px;" tools="#t_rank&quo ...

  7. linux_fedora nexus_auto_start

      fedora20发布,不对rc.local支持,其实只是删除了rc.local文件,如果想在开机时能够运行自己写的脚本,只要新建rc.local文件就可以了,下面让我们来测试下吧: 环境:fedo ...

  8. angular入门系列教程2

    主题: 本篇主要介绍下angular里的一些概念,并且在咱们的小应用上加上点料.. 概念(大概了解即可,代码中遇到的会有详细注释): 模板:动态模板,是动态的,直接去处理DOM的,而不是通过处理字符串 ...

  9. [转载]点评阿里云、盛大云等国内IaaS产业

    免责声明:     本文转自网络文章,转载此文章仅为个人收藏,分享知识,如有侵权,请联系博主进行删除.     原文作者:刘黎明      原文地址:http://www.chinacloud.org ...

  10. Unity3D 游戏开发构架篇 ——角色类的设计与持久化

    在游戏开发中,游戏角色占了很大的篇幅,可以说游戏中所有的内容都是由主角所带动.这里就介绍一下角色类的设计和持久化. 一.角色类应用场景和设计思想 游戏中的角色类型不一而足,有不同的技能,有不同的属性等 ...