等价类计数问题首先要构造出群

首先,给出的洗牌法就相当于置换,

再加上置换(1)(2)(3)……(n),可以构成一个包含m+1个置换的置换群;

这里要解释一下构成置换群的四个条件

  1. 封闭性 任意两个置换相乘所得的置换还在群内 题目中已经给定保证任意多次洗牌都可用这m种洗牌法中的一种代替

  2. 结合性 显然置换相乘本身就满足结合律

  3. 单位元 存在一个单位元e是的a*e=a成立,显然置换(1)(2)(3)……(n)就是这样一个单位元

  4. 逆元   任意一个置换a都存在一个置换b使得a*b=e 这是有题目给定条件对每种洗牌法,都存在一种洗牌法使得能回到原状态。

这样置换群就弄出来了,然后就是根据Burnside引理,找出每个置换不动点的个数

每个置换可以拆成多个不相交的循环的积,不动点就要求每个循环内元素颜色相同

由于颜色存在数量限制,不能用polya求,只能用dp求出

最后注意求平均数设计到除法取模,我们还要求m+1的乘法逆元

  1. var s,r:array[..] of longint;
  2.     f:array[..,..,..] of longint;
  3.     ans,x,y,i,j,n,m,a,b,c,p,t:longint;
  4.     v:array[..] of boolean;
  5.  
  6. procedure exgcd(a,b:longint;var x,y:longint);
  7.   var xx,yy:longint;
  8.   begin
  9.     if b= then
  10.     begin
  11.       x:=;
  12.       y:=;
  13.     end
  14.     else begin
  15.       exgcd(b,a mod b,x,y);
  16.       xx:=x;
  17.       yy:=y;
  18.       x:=yy;
  19.       y:=xx-a div b*yy;
  20.     end;
  21.   end;
  22.  
  23. function calc(n:longint):longint;  
  24. //f[i,j,k]表示到第i个循环,红色用了j次,蓝色用了k次,由于每个循环内颜色相同,所以绿色用的次数可以根据i,j,k算出
  25.   var t,i,j,k:longint;
  26.   begin
  27.     f[,,]:=;
  28.     t:=;
  29.     for i:= to n do
  30.     begin
  31.       t:=t+s[i];
  32.       for j:= to a do
  33.         for k:= to b do
  34.         begin
  35.           f[i,j,k]:=;
  36.           x:=t-j-k;
  37.           if (x>c) then continue;
  38.           if x< then break;
  39.           if j>=s[i] then f[i,j,k]:=(f[i,j,k]+f[i-,j-,k]) mod p;  //要涂就一定要足够涂满循环内全部元素
  40.           if k>=s[i] then f[i,j,k]:=(f[i,j,k]+f[i-,j,k-]) mod p;
  41.           if x>=s[i] then f[i,j,k]:=(f[i,j,k]+f[i-,j,k]) mod p;
  42.         end;
  43.     end;
  44.     exit(f[n,a,b]);
  45.   end;
  46.  
  47. begin
  48.   readln(a,b,c,m,p);
  49.   n:=a+b+c;
  50.   for i:= to n do
  51.     s[i]:=;
  52.   ans:=calc(n);
  53.   for i:= to m do
  54.   begin
  55.     for j:= to n do
  56.       read(r[j]);
  57.     fillchar(v,sizeof(v),false);
  58.     fillchar(s,sizeof(s),);
  59.     t:=;
  60.     for j:= to n do
  61.       if not v[j] then
  62.       begin
  63.         x:=j;
  64.         inc(t);
  65.         while not v[x] do
  66.         begin
  67.           v[x]:=true;
  68.           inc(s[t]);  //统计循环规模
  69.           x:=r[x];
  70.         end;
  71.       end;
  72.     ans:=(ans+calc(t)) mod p;  
  73.   end;
  74.   x:=;
  75.   y:=;
  76.   exgcd(m+,p,x,y);
  77.   writeln(ans*(x+p) mod p);  //注意通过扩展欧几里得求出的乘法逆元可能是负数
  78. end.

bzoj1004的更多相关文章

  1. 【bzoj1004】 HNOI2008—Cards

    http://www.lydsy.com/JudgeOnline/problem.php?id=1004 (题目链接) 题意 n张卡片,染成3种颜色,每种颜色只能染固定张数.给出一些洗牌方案,问染色方 ...

  2. 【BZOJ1004】Cards(组合数学,Burnside引理)

    [BZOJ1004]Cards(组合数学,Burnside引理) 题面 Description 小春现在很清闲,面对书桌上的N张牌,他决定给每张染色,目前小春只有3种颜色:红色,蓝色,绿色.他询问Su ...

  3. BZOJ1004 HNOI2008Cards(Burnside引理+动态规划)

    直接给了一个置换群(当然要自己手动加上不洗牌的情况).考虑求不动点数量即可.对于一个置换,求出所有循环的长度,然后设f[i][x][y]为给前i个循环着色后,用了x张红色卡片.y张绿色卡片的方案数,d ...

  4. 【BZOJ1004】[HNOI2008]Cards Burnside引理

    [BZOJ1004][HNOI2008]Cards 题意:把$n$张牌染成$a,b,c$,3种颜色.其中颜色为$a,b,c$的牌的数量分别为$sa,sb,sc$.并且给出$m$个置换,保证这$m$个置 ...

  5. [BZOJ1004] [HNOI2008]Cards解题报告(Burnside引理)

    Description 小春现在很清闲,面对书桌上的N张牌,他决定给每张染色,目前小春只有3种颜色:红色,蓝色,绿色.他询问Sun有多少种染色方案,Sun很快就给出了答案.进一步,小春要求染出Sr张红 ...

  6. BZOJ1004 [HNOI2008]Cards 【burnside定理 + 01背包】

    题目链接 BZOJ1004 题解 burnside定理 在\(m\)个置换下本质不同的染色方案数,等于每种置换下不变的方案数的平均数 记\(L\)为本质不同的染色方案数,\(m\)为置换数,\(f(i ...

  7. bzoj1004 [HNOI2008]Cards 置换群+背包

    [bzoj1004][HNOI2008]Cards 2014年5月26日5,3502 Description 小春现在很清闲,面对书桌上的N张牌,他决定给每张染色,目前小春只有3种颜色:红色,蓝色,绿 ...

  8. BZOJ1004: [HNOI2008]Cards

    三维01背包算出在每一个置换下不变的染色方案数,Burnside引理计算答案. PS:数据太水所以只算恒等置换也是可以过的. #include<bits/stdc++.h> using n ...

  9. BZOJ1004 [HNOI2008]Cards(Polya计数)

    枚举每个置换,求在每个置换下着色不变的方法数,先求出每个循环的大小,再动态规划求得使用给定的颜色时对应的方法数. dp[i][j][k]表示处理到当前圈时R,B,G使用量为i,j,k时的方法数,背包思 ...

  10. 【BZOJ1004】【HNOI20008】cards

    看黄学长的代码才写出来的,sro_hzwer_orz 原题: 小春现在很清闲,面对书桌上的N张牌,他决定给每张染色,目前小春只有3种颜色:红色,蓝色,绿色.他询问Sun有多少种染色方案,Sun很快就给 ...

随机推荐

  1. java main函数不执行?

    今天脑袋短路,对于这个问题纠结了好久.这个问题具体是这样的: public class test { public static void main(String[] args) { test2 t ...

  2. 【转】字符编码笔记:ASCII,Unicode和UTF-8

    今天整理笔记,关于NSString转NSData时,什么时候使用NSUTF8StringEncoding,或者NSASCIIStringEncoding,或者 NSUnicodeStringEncod ...

  3. Q105971:Converting a Regular GUID to a Compressed GUID

    Quote from:  http://flexerasoftware.force.com/articles/en_US/INFO/Q105971 Synopsis   The Windows Ins ...

  4. 九度OJ 1372 最大子向量和(连续子数组的最大和)

    题目地址:http://ac.jobdu.com/problem.php?pid=1372 题目描述: HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学.今天JOBDU测试组开完会后,他又发话了:在 ...

  5. 四层运维工具nc

        nc命令全名为netcat,顾名思义就是通过TCP或UDP从网络读写数据. 很多事情不一定非得抓包,nc也能发挥巨大作用. 1.传输文件 使用<>重定向符(只适用单文件,不推荐.失 ...

  6. linux进程间通信--有名管道

    有名管道 只有当一个库函数失败时,errno才会被设置.当函数成功运行时,errno的值不会被修改.这意味着我们不能通过测试errno的值来判断是否有错误存在.反之,只有当被调用的函数提示有错误发生时 ...

  7. ES6笔记-字符串方法

    字符串检索方法,indexOf(searchValue,fromIndex)//参数1必需,检索查询的字符串或者值,参数2选题,规定检索的起始位置,不设置默认从0开始 indexOf()方法返回检索字 ...

  8. 【java版坦克大战---准备篇】 java 绘图

    要写坦克大战当然要先画出坦克.java画图是基础. package com.game; import java.awt.*; import javax.swing.*; public class Pr ...

  9. 解决android调用IIS Express中的WCF服务时,出现错误400问题

    IIS Express仅支持localhost主机名地址访问. 找到IIS Express Config文件下的 applicationhost.confi   修改配置 再来调试android应用, ...

  10. Lucene4.9学习笔记——Lucene建立索引

    基本上创建索引需要三个步骤: 1.创建索引库IndexWriter对象 2.根据文件创建文档Document 3.向索引库中写入文档内容 这其中主要涉及到了IndexWriter(索引的核心组件,用于 ...