SPOJ 422 Transposing is Even More Fun ——Burnside引理
这题目就比较有趣了。
大概题目中介绍了一下计算机的储存方法,给一个$2^a*2^b$的矩阵。
求转置。但是只能交换两个数,求所需要的步数。
首先可以把变化前后的位置写出来,构成了许多的循环。左转将狼踩尽博客
然后就是求循环的个数了。
发现循环都是左移形成的,可以直接计算本质不同的串的个数。
(这里用到一个小优化,把最小的循环节找出来可以简化问题,这样子可以变成循环任意多次,就能用欧拉函数了)
然后就是一顿模板 (POJ2154)
然后交上去
TLE。
SPOJ太慢了
1s跑不过40w的$nsqrt(n)$
然后把2的幂次预处理出来,然后吧逆元线性递推。还是TLE。
然后去看别人的博客,讲了一种奇怪的做法,然而我并没有看懂是什么情况。
也没有任何人讲到。
那看看算法主体中哪些地方还可以优化。
然后怒用调和级数处理因子,然后把vector换成了邻接表,然后A掉了。
#include <vector>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define maxn 1000005
int pri[maxn],top,phi[maxn],vis[maxn];
int pw[maxn<<2],inv[maxn]; #define ll long long
#define F(i,j,k) for (int i=j;i<=k;++i)
#define D(i,j,k) for (int i=j;i>=k;--i) int h[maxn*20],to[maxn*20],ne[maxn*20],en=0; void add(int a,int b)
{
to[en]=b;ne[en]=h[a];h[a]=en++;
} inline char nc(){
static char buf[100000],*p1=buf,*p2=buf;
return p1==p2&&(p2=(p1=buf)+fread(buf,1,100000,stdin),p1==p2)?EOF:*p1++;
}
inline void read(int &x){
char c=nc(),b=1;
for (;!(c>='0' && c<='9');c=nc()) if (c=='-') b=-1;
for (x=0;c>='0' && c<='9';x=x*10+c-'0',c=nc()); x*=b;
} int t,a,b,d,c,p=1000003,e; void Shaker()
{
phi[1]=1;
F(i,2,maxn-1)
{
if (!vis[i]) pri[++top]=i,phi[i]=i-1;
for (int j=1;j<=top&&(ll)i*pri[j]<maxn;++j)
{
vis[i*pri[j]]=1;
if (i%pri[j]==0){phi[i*pri[j]]=phi[i]*pri[j];break;}
phi[i*pri[j]]=phi[i]*phi[pri[j]];
}
}
inv[1]=1; F(i,2,maxn-1) inv[i]=(p-(ll)p/i*inv[p%i])%p;
pw[0]=1;
F(i,1,(maxn<<2)-1) pw[i]=pw[i-1]*2%p;
F(i,1,maxn-1)
for (int j=i;j<maxn;j+=i)
add(j,i);
} int ksm(int a,int b)
{
int ret=1;
for (;b;b>>=1,a=(ll)a*a%p) if (b&1) ret=(ll)ret*a%p;
return ret;
} int gcd(int a,int b)
{return b==0?a:gcd(b,a%b);} int main()
{
memset(h,-1,sizeof h);
Shaker();
read(t);
while(t--)
{
int ans=0;
read(a);read(b);
if (a*b==0) {printf("0\n");continue;}
d=gcd(a,b); c=a+b; c=c/d; e=pw[d];
for (register int i=h[c];i>=0;i=ne[i])
ans=(ans+(ll)phi[c/to[i]]*pw[d*to[i]]%p)%p;
ans=(ll)ans*inv[(a+b)/d]%p;
printf("%d\n",((pw[c*d]-ans)%p+p)%p);
}
}
SPOJ 422 Transposing is Even More Fun ——Burnside引理的更多相关文章
- SPOJ 422 Transposing is Even More Fun(polay计数)
题目链接:http://www.spoj.com/problems/TRANSP2/ 题意: 思路:不妨设a=1,b=2, 我们发现(001,010,100)组成一个置换,(011,110,101)组 ...
- 解题:SPOJ 422 Transposing is Even More Fun
题面 这种换来换去的东西很容易想到置换群那一套,然后题目甚至还暗示了二进制=.= 直接换的话显然是$2^{a+b}$次,但是一个循环节里可以少换一次,然后问题就变成了数循环节 在一个循环节里的位置有什 ...
- [bzoj 1004][HNOI 2008]Cards(Burnside引理+DP)
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1004 分析: 1.确定方向:肯定是组合数学问题,不是Polya就是Burnside,然后题目上 ...
- POJ 2888 Magic Bracelet(Burnside引理,矩阵优化)
Magic Bracelet Time Limit: 2000MS Memory Limit: 131072K Total Submissions: 3731 Accepted: 1227 D ...
- BZOJ 1004 Cards(Burnside引理+DP)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1004 题意:三种颜色的扑克牌各有Sr,Sb,Sg张.给出m种置换.两种染色方案在某种置换 ...
- BZOJ_[HNOI2008]_Cards_(置换+Burnside引理+乘法逆元+费马小定理+快速幂)
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1004 共n个卡片,染成r,b,g三种颜色,每种颜色的个数有规定.给出一些置换,可以由置换得到的 ...
- [BZOJ 1004] [HNOI2008] Cards 【Burnside引理 + DP】
题目链接:BZOJ - 1004 题目分析 首先,几个定义和定理引理: 群:G是一个集合,*是定义在这个集合上的一个运算. 如果满足以下性质,那么(G, *)是一个群. 1)封闭性,对于任意 a, b ...
- BZOJ 1004: [HNOI2008]Cards( 置换群 + burnside引理 + 背包dp + 乘法逆元 )
题意保证了是一个置换群. 根据burnside引理, 答案为Σc(f) / (M+1). c(f)表示置换f的不动点数, 而题目限制了颜色的数量, 所以还得满足题目, 用背包dp来计算.dp(x,i, ...
- BZOJ 1004 HNOI2008 Cards Burnside引理
标题效果:特定n张卡m换人,编号寻求等价类 数据保证这m换人加上置换群置换后本身构成 BZOJ坑爹0.0 条件不那么重要出来尼玛怎么做 Burnside引理--昨晚为了做这题硬啃了一晚上白书0.0 都 ...
随机推荐
- Problem J: 搜索基础之红与黑
Problem J: 搜索基础之红与黑 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 170 Solved: 100[Submit][Status][ ...
- Problem A: 李白打酒
Problem A: 李白打酒 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 825 Solved: 373[Submit][Status][Web ...
- python_70_内置函数2
#hex() 转16进制 oct()转8进制 print(hex(255)) print(oct(10)) #id() 返回内存地址 print(id('a')) ''' isinstance(obj ...
- C#语句对Access中数据更新问题――Update语法错误
所有字段最好都用[] 括起来: string sqlUpdate = "update UserInfo set [password] = '" + pass + "',[ ...
- vue 服务代理 调用第三方api
项目中前期需要调用第三方API来获取汇率.因为直接调用会有跨域的问题,所以使用来服务代理. 在config配置代理可以这样写: 而调用接口就可以这样写: 坑:配置完成后一直报500,开始怀疑人生.最后 ...
- TO_DATS() AS ABAP_DATE
有的时候一个想不到的小问题,,才是致命的问题!
- Vue -computed传参数
vue 中computed想传递参数怎么办? 闭包在这里起到的重要的作用 <input v-model="newItem(key,val)" type="text& ...
- 第48课 thinkphp5添加商品库
目录 思路: 1. html页面里属性下拉框里的值是从goods_attr联attr里的查出来传到模板里的.在属性的下拉栏里展示出来 2. html页面里用二维数组的结构goods_attr[{$k} ...
- 如何使用pyinstaller打包32位的exe
说明:原来安装的python为64位,故安装的pyinstaller和打包后的exe都为64位.而64位的exe文件在32位的win7操作系统下是无法执行的,显示不兼容.网上查询发现,简单(可能不方便 ...
- wireshark_1.6.2 使用笔记
表示ip1是否有访问ip2,进行抓包