【题目链接】:http://www.lydsy.com/JudgeOnline/problem.php?id=1004

【题意】



给你sr+sb+sg张牌,(令n=sr+sb+sg),让你把这n张牌染成3种颜色(红蓝绿),且红色sr张,蓝色sb张,绿色sg张;

同时再给你m个变化关系change[i],这里从左往右数第change[i]张牌可以移动到第i个位置;

m行的变化关系每行都有n个change,即change[1..n]

然后任意两种染色的方案只有在用m个变化关系不能互相到达时才认为不同;(每个变化可以任意次数使用)

【题解】



看了别人的题解,都说是burnside定理;

这个定理的内容是说;

m个变化,k种颜色染色;

本质不同的染色方案数是

m种变化中特殊的染色方案的和的平均数

一种变化可能有多种特殊的染色方案;

这里第i种变化的特殊方案指的是:

在把每张纸染色之后,无论经过多少次第i行的这个变化,这n张纸的颜色还是维持一开始染色的那个样子;

我们知道每一行的变化里面肯定有多个循环节,既然要前后不变;那么就让同一个循环节里面的纸的颜色一样就好;

这样,我们可以一个变化一个变化的处理出m个变化的特殊的染色方案的和;

然后再除m就好;

这里对于求某一个变化的特殊染色方案数;

可以用dp来搞;(背包方案数);

假设这一行的变化有cnt个循环节;

则对于每个循环节来说都有3种可能,染成红色或者染成蓝色或者染成绿色;

这里背包的重量就是这个循环节的长度(即整个循环节都染成同一种颜色);

写成3维的,然后逆序更新就好(按照01背包的更新方式);

f[i][j][k]表示红色染了i个,蓝色染了j个,绿色染了k个的方案数;

最后返回f[sr][sb][sg]就好;

f[0][0][0]=1;

因为答案涉及到了除法取模;

所以还得写个乘法逆元;

这里可以不用写扩展欧几里得了;

又学了一个新的方法;

在gcd(a,p)==1的时候(即互质),且p为质数;

(a^(p-1))%p=1;

则有(a*(a^(p-2)))%p=1;

这里就能看出来了a^(p-2)就是a的乘法逆元;

这里因为m+1<=p且p为质数;

所以m不可能为p的倍数,则m和p肯定是互质的;

也就满足上述条件了;

写个快速幂呗;

直接暴力乘也ok的吧.

(感觉这个费马小定理版的乘法逆元好记多了..)



【完整代码】

/**************************************************************
Problem: 1004
User: chengchunyang
Language: C++
Result: Accepted
Time:2132 ms
Memory:11740 kb
****************************************************************/ #include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define rei(x) scanf("%d",&x)
#define rel(x) scanf("%I64d",&x) typedef pair<int,int> pii;
typedef pair<LL,LL> pll; const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 110; int sr,sb,sg,m,p,bh[N][N],n;
LL sumc = 0,f[N][N][N],siz[N],ny = 1;
bool bo[N]; LL js(int x)
{
int num = 0;
memset(bo,false,sizeof bo);
memset(siz,0,sizeof siz);
memset(f,0,sizeof f);
rep1(i,1,n)
{
if (bo[i]) continue;
num++;
int p = bh[x][i];
while (!bo[p]) bo[p] = true,siz[num]++,p = bh[x][p];
} f[0][0][0] = 1; rep1(i,1,num)
rep2(j,sb,0)
rep2(k,sr,0)
rep2(l,sg,0)
{
if (j>=siz[i]) f[j][k][l] = (f[j][k][l]+f[j-siz[i]][k][l])%p;
if (k>=siz[i]) f[j][k][l] = (f[j][k][l]+f[j][k-siz[i]][l])%p;
if (l>=siz[i]) f[j][k][l] = (f[j][k][l]+f[j][k][l-siz[i]])%p;
}
return f[sb][sr][sg];
} void ksm(int x)
{
if (!x) return;
ksm(x>>1);
ny = (ny*ny)%p;
if (x&1)
ny = (ny*m)%p;
} int main()
{
//freopen("F:\\rush.txt","r",stdin);
rei(sr),rei(sb),rei(sg),rei(m),rei(p);
n = sr+sb+sg;
rep1(i,1,m)
rep1(j,1,n)
rei(bh[i][j]);
m++;
rep1(i,1,n)
bh[m][i] = i;
rep1(i,1,m)
sumc = (sumc+js(i))%p;
ksm(p-2);
sumc = (sumc*ny)%p;
cout << sumc << endl;
return 0;
}

【BZOJ 1004】 [HNOI2008]Cards的更多相关文章

  1. 【BZOJ 1004】 1004: [HNOI2008]Cards (置换、burnside引理)

    1004: [HNOI2008]Cards Description 小春现在很清闲,面对书桌上的N张牌,他决定给每张染色,目前小春只有3种颜色:红色,蓝色,绿色.他询问Sun有多少种染色方案,Sun很 ...

  2. 【BZOJ 1005】[HNOI2008]明明的烦恼(暴力化简法)

    [题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1005 [题意] 中文题 [题解] 一棵节点上标有序号的树会和一个prufer数列唯一对 ...

  3. 【BZOJ 1011】[HNOI2008]遥远的行星

    [题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1011 [题意] [题解] 这里的答案误差不超过5%是突破点; 如果是直接暴力写; 复杂 ...

  4. 【BZOJ 1008】[HNOI2008]越狱

    [题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1008 [题意] [题解] 相邻就会犯罪的话; 可以考虑它的反面; 即让所有相同信仰的人 ...

  5. 【BZOJ 1007】 [HNOI2008]水平可见直线

    [题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1007 [题意] [题解] 这个人讲得很好 http://blog.csdn.net/o ...

  6. 【BZOJ 1005】[HNOI2008]明明的烦恼(化简的另一种方法)

    [题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1005 [题意] [题解] 题目和题解在上一篇; 这里 对 [(m^(n-2-tot)) ...

  7. 【BZOJ 1004】【HNOI 2008】Cards

    http://www.lydsy.com/JudgeOnline/problem.php?id=1004 注意数据给出的m是一个没有单位元的置换群! 用Burnside引理,然后对每个置换群dp一下就 ...

  8. 【BZOJ 1010】 [HNOI2008]玩具装箱toy (斜率优化)

    1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 9330  Solved: 3739 Descriptio ...

  9. 【BZOJ 1006】[HNOI2008]神奇的国度

    Description K国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即AB相互认识,BC相互认识,CA相互认识,是简洁高效的.为了巩固三角关系,K国禁止四边关系,五边关系 ...

随机推荐

  1. Docker.[3].镜像操作.

    Docker.[3].镜像操作. 熟悉基础指令: 查看本地镜像 docker images 查看本地镜像 docker image list (和上面显示的结果一样.) 删除本地镜像 docker r ...

  2. 总体<导学>

    有一些奇奇怪怪的数据集 波士顿房价数据集 使用sklearn.datasers.load_boston 加载相关的数据集 重要参数 return_X_y 表示是否返回target (价格) 默认为Fa ...

  3. FJWC2018

    晚上水到8:40,感觉药丸. 把电脑带回寝室,大半夜敲键盘…… bzoj5254红绿灯 泰迪每天都要通过一条路从家到学校,这条路的起点是泰迪家,终点则是学校. 这条路中间还有n个路口,从第i-1个路口 ...

  4. 只在需要的时候 Polyfill 你的 JavaScript 代码

    本文转载自 Pascal Klau,他是一名来自德国南部的实习生,他讨厌不必要的 HTTP 请求,也不爱吃西兰花.Pascal 将说明使用 polyfill 服务的一种方式,在这种方式下你可能可以完全 ...

  5. MAC+VS Code+Python+Markdown调试配置

    目录 VS Code官网下载 VS Code插件推荐 VS Code Python环境配置 Markdown配置 VS Code官方文档 VS Code官网下载 VS Code官网下载地址 VS Co ...

  6. 两篇论文之CNN中正交操作

    CNN的权值正交性和特征正交性,在一定程度上是和特征表达的差异性存在一定联系的. 下面两篇论文,一篇是在训练中对权值添加正交正则提高训练稳定性,一篇是对特征添加正交性的损失抑制过拟合. 第一篇:Ort ...

  7. Contacts源码分析(一、概述)

    代码版本: Contact code version: 4.4.2 一 打开Log开关:如if (Log.isLoggable(Constants.PERFORMANCE_TAG, Log.DEBUG ...

  8. Mysql Command

    数据库备份: mysqldump -uroot -p -h 192.168.1.190 --default-character-set=utf8 $dbname > backup_db.sql ...

  9. js+canvas实现象棋的布局、走棋位置提示、走棋代码

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  10. Java8 Date与LocalDate互转

    Java8 日期时间API,新增了LocalDate.LocalDateTime.LocalTime等线程安全类,接下来要说的是LocalDate与java.util.Date之间的转换. 1.Loc ...