排列+函数映射——hdu6038好题
/*
引理:[0,n-1]的排列,i向a[i]连边,那么每个数必定在一个环中
所以数组a可以分割成一些环,数组b也可以分割成一些环
先讨论a的一个环
a[a1]=a2 a[a2]=a3 a[a3]=a4 a[a4]=a5 a[a5]=a6 a[a6]=a1 这个环长度为6 那么套到函数 f[i]=b[ f[a[i] ]中
f[a1]=b[f[a2]]
f[a2]=b[f[a3]]
f[a3]=b[f[a4]]
f[a4]=b[f[a5]]
f[a5]=b[f[a6]]
f[a6]=b[f[a1]] 可以把b[f[a[i]]] = f[i] 当成是b数组的下标i到b[i]的映射 ,只不过这里的下标i 是f[a[i]]], b[i] 是f[i]
(可以发现这个f函数有点像反函数的感觉) 那么显然因为b也有和a类似的循环节,我们要找到一个b的循环节来套到上述映射里,这个循环节长度必须是上面循环节的约数
因为a[i]=ai 的循环节是6,那么b关于f的映射必定要能整除6
如果不是约数,那么f[ai]可能会对应到不同的值,这就不满足映射条件了 求方案数,设a其中一个长度为len的环的组成方案有k种,那么计算k时b所有长为len约数的环都要算上贡献
最后的结果就是 mul(k),即所有k相乘
*/ #include<bits/stdc++.h>
using namespace std;
#define maxn 100005
#define mod 1000000007
#define ll long long
int a[maxn],b[maxn],n,m,cnt1[maxn],cnt2[maxn],vis[maxn];
ll tot[maxn]; ll Pow(ll a,ll b){
ll res=;
while(b){
if(b%)res=res*a%mod;
b>>=;a=a*a%mod;
}
return res;
} int main(){
int t=;
while(cin>>n>>m){
t++;
memset(cnt1,,sizeof cnt1);
memset(cnt2,,sizeof cnt2); for(int i=;i<n;i++)scanf("%d",&a[i]);
for(int i=;i<m;i++)scanf("%d",&b[i]); memset(vis,,sizeof vis);
for(int i=;i<n;i++)
if(!vis[i]){
int p=i,len=;
vis[i]=;
while(a[p]!=i)
p=a[p],len++,vis[p]=;
cnt1[len]++;
} memset(vis,,sizeof vis);
for(int i=;i<m;i++)
if(!vis[i]){
int p=i,len=;
while(b[p]!=i)
p=b[p],len++,vis[p]=;
cnt2[len]++;
} memset(tot,,sizeof tot);
for(int len=;len<=m;len++)//枚举b环的长度len
for(int j=;j*len<=n;j++)
tot[j*len]=(tot[j*len]+cnt2[len]*len%mod)%mod; //每个长度为len的a环都有tot[len]种安排方案
ll ans=;
for(int len=;len<=n;len++)
if(cnt1[len])
ans=ans*Pow(tot[len],cnt1[len])%mod; printf("Case #%d: %lld\n",t,ans);
}
return ;
}
排列+函数映射——hdu6038好题的更多相关文章
- C++ 函数映射使用讲解
想想我们在遇到多语句分支时是不是首先想到的是 switc case 和 if else if ... 这2种方式在编码方面确实简单少,但是当分支达到一定数量后,特别是分支内部有嵌套大段代码或者再嵌套分 ...
- 5_PHP数组_3_数组处理函数及其应用_7_数组排列函数
以下为学习孔祥盛主编的<PHP编程基础与实例教程>(第二版)所做的笔记. 数组排列函数 1. sort() 函数 程序: <?php $array = array("img ...
- hdu6038 Function 函数映射
/** 题目:hdu6038 Function 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6038 题意:给定一个a排列[0,n-1],一个b排列[0, ...
- Python排列函数:sort、sorted
排序函数介绍:sort()和sorted()都属于Python list的排序方法 区别:sort()属于永久性排列,直接改变该list: sorted属于暂时性排列,会产生一个新的序列. #sort ...
- Exponial~(欧拉函数)~(发呆题)
Description Everybody loves big numbers (if you do not, you might want to stop reading at this point ...
- MS笔试中的一个关于函数返回的“小”题
Which of following C++ code is correct ? A. int f() { ); return *a; } B. int *f() { int a[3] = {1,2, ...
- map()函数映射
map()函数(映射) pattern = "abba" str = "dog cat cat dog" res=str.split() print(list( ...
- 百练8216-分段函数-2016正式A题
百练 / 2016计算机学科夏令营上机考试 已经结束 题目 排名 状态 统计 提问 A:分段函数 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 编写程序 ...
- hdu1521 排列组合 指数型母函数模板题
排列组合 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
随机推荐
- 一只青蛙一次可以跳1阶或者2阶,n阶,有多少种到达终点的方式。
前两天面试遇到的一个题,当时没有想清楚,今天想了一下,po出来: # -*-encoding:utf-8-*- import sys end = 0 # 终点 cnt = 0 # 统计组合方式 def ...
- Thinkphp5获取文件上传信息
Thinkphp5内置有处理文件上传的方法,因在开发文档没有找到获取上传文件基本信息的说明,故在这里做一下记录. $file = request()->file('input类型为file的na ...
- Jlink V8固件恢复
使用附件中的PDF文档步骤即可,但是千万千万记得两点,更新系统很关键,很关键 1.WINXP系统 2.32Bit系统 切记切记,其他的win7,winxp 64就不用试着更新了,全部是坑 大概步骤 J ...
- checklistbox用法
删除:CheckListBox.DeleteSelected; 上下移: CheckListBox.Items.Move 删除用 CheckListBox1.Items.Delete(Index); ...
- noip2002 普及组 过河卒
题目描述 棋盘上A点有一个过河卒,需要走到目标B点.卒行走的规则:可以向下.或者向右.同时在棋盘上C点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点.因此称之为"马拦过 ...
- 服务器安装TeamViewer 13
服务器安装TeamViewer 13 服务器上安装TeamViewer,网上找了个教程开始安装,里面有坑,安装时要根据自己的情况而定.Linux系统更新太快,网上教程可能会有一些出入. TeamVie ...
- java.io.IOException: Could not find resource SqlMapConfig.xml
java.io.IOException: Could not find resource SqlMapConfig.xml 创建mybatis工程时遇到的问题 问题的来源:当我们在项目中和src同级的 ...
- myeclipse 启动卡住的解决办法
myeclipse 启动卡住的解决办法 今天启动myeclipse突然卡住,CPU一直占用,启动任务管理器强制关闭.重启myeclipse,重启电脑都不能够解决. 上网查找,在工程路径(工作空间的路径 ...
- PAT_A1062#Talent and Virtue
Source: PAT A1062 Talent and Virtue (25 分) Description: About 900 years ago, a Chinese philosopher S ...
- Java随机访问文件
使用随机访问文件,我们可以从文件读取以及写入文件.使用文件输入和输出流的读取和写入是顺序过程.使用随机访问文件,可以在文件中的任何位置读取或写入.RandomAccessFile类的一个对象可以进行随 ...