AtCoder AGC031D A Sequence of Permutations (群论、置换快速幂)
题目链接
https://atcoder.jp/contests/agc031/tasks/agc031_d
题解
这居然真的是个找规律神题。。。
首先要明白置换的一些基本定义,置换$p$和$q$的复合$a$定义为$a_i=p_$, 记作$a=pq$. 有定理$(pq){-1}=q{-1}p^{-1}$.
显然题目里定义的$f(p,q)=qp^{-1}$.
然后打表打出前几项:
\(a_1=p\)
\(a_2=q\)
\(a_3=qp^{-1}\)
\(a_4=qp^{-1}q^{-1}\)
\(a_5=qp^{-1}q^{-1}pq^{-1}\)
\(a_6=qp^{-1}q^{-1}p^2q^{-1}\)
\(a_7=qp^{-1}q^{-1}pqpq^{-1}\)
\(a_8=qp^{-1}q^{-1}pqp^{-1}qpq^{-1}\)
好像……规律并不明显啊……
好吧,结论是$a_n=ga_g^{-1}$, 其中$g=qp^{-1}q^{-1}p$. (这是怎么看出来的……)
知道了结论,我们还是比较容易归纳证明的: 显然$gg^{-1}=e$ ($e$为单位元,\(e_i=i\)), 于是$a_n=(ga_g^{-1})(ga_g^{-1}){-1}=ga_a_{-1}g^{-1}=ga_g^{-1}$.
于是设$m'=\lfloor \frac{6}\rfloor, n'=m-6m'$, \(a_n=g^{m'}a_{n'}g^{-m'}\), 直接快速幂计算即可,时间复杂度$O(n\log m)$或$O(n)$.
代码
#include<cstdio>
#include<cstdlib>
#include<cassert>
#include<iostream>
using namespace std;
inline int read()
{
	int x=0; bool f=1; char c=getchar();
	for(;!isdigit(c);c=getchar()) if(c=='-') f=0;
	for(; isdigit(c);c=getchar()) x=(x<<3)+(x<<1)+(c^'0');
	if(f) return x;
	return -x;
}
const int N = 1e5;
const int lgM = 30;
int p[N+3],q[N+3],pp[N+3],qq[N+3];
int g[N+3],f[N+3],ff[N+3];
int tmp[N+3];
int aux[N+3];
int ans[N+3];
int a[7][N+3];
int n,m;
int main()
{
	scanf("%d%d",&n,&m);
	for(int i=1; i<=n; i++) scanf("%d",&p[i]),pp[p[i]] = i;
	for(int i=1; i<=n; i++) scanf("%d",&q[i]),qq[q[i]] = i;
	for(int i=1; i<=n; i++) a[1][i] = p[i],a[2][i] = q[i];
	for(int k=3; k<=6; k++)
	{
		for(int i=1; i<=n; i++) a[k][a[k-2][i]] = a[k-1][i];
	}
	for(int i=1; i<=n; i++) g[i] = q[pp[qq[p[i]]]],f[i] = i,tmp[i] = g[i];
	int nn = m%6==0?6:m%6; m = (m-1)/6;
	for(int i=0; m; i++)
	{
		if(m&(1<<i))
		{
			m-=(1<<i);
			for(int j=1; j<=n; j++) aux[j] = f[tmp[j]];
			for(int j=1; j<=n; j++) f[j] = aux[j];
		}
		for(int j=1; j<=n; j++) aux[j] = tmp[tmp[j]];
		for(int j=1; j<=n; j++) tmp[j] = aux[j];
	}
	for(int i=1; i<=n; i++) ff[f[i]] = i;
	for(int i=1; i<=n; i++) ans[i] = f[a[nn][ff[i]]];
	for(int i=1; i<=n; i++) printf("%d ",ans[i]);
	return 0;
}
AtCoder AGC031D A Sequence of Permutations (群论、置换快速幂)的更多相关文章
- Atcoder Grand Contest 031 D - A Sequence of Permutations(置换+猜结论)
		Atcoder 题面传送门 & 洛谷题面传送门 猜结论神题. 首先考虑探究题目中 \(f\) 函数的性质,\(f(p,q)_{p_i}=q_i\leftarrow f(p,q)\circ p= ... 
- HDU 5950 Recursive sequence 【递推+矩阵快速幂】 (2016ACM/ICPC亚洲区沈阳站)
		Recursive sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Other ... 
- 杭电多校第七场 1010 Sequence(除法分块+矩阵快速幂)
		Sequence Problem Description Let us define a sequence as below f1=A f2=B fn=C*fn-2+D*fn-1+[p/n] Your ... 
- HDU-6395 多校7 Sequence(除法分块+矩阵快速幂)
		Sequence Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ... 
- POJ 2778 DNA Sequence (ac自动机+矩阵快速幂)
		DNA Sequence Description It's well known that DNA Sequence is a sequence only contains A, C, T and G ... 
- POJ2778 DNA Sequence(AC自动机+矩阵快速幂)
		题目给m个病毒串,问不包含病毒串的长度n的DNA片段有几个. 感觉这题好神,看了好久的题解. 所有病毒串构造一个AC自动机,这个AC自动机可以看作一张有向图,图上的每个顶点就是Trie树上的结点,每个 ... 
- POJ 2778 DNA Sequence(AC自动机+矩阵快速幂)
		题目链接:http://poj.org/problem?id=2778 题意:有m种DNA序列是有疾病的,问有多少种长度为n的DNA序列不包含任何一种有疾病的DNA序列.(仅含A,T,C,G四个字符) ... 
- 【POJ】2778 DNA Sequence(AC自动机+矩阵快速幂)
		题目 传送门:QWQ 分析 对着Trie图搞快速幂. 为什么这样是对的呢? 详见:http://www.matrix67.com/blog/archives/276 有些地方还不是很理解......为 ... 
- ACM学习历程—HDU5667 Sequence(数论 && 矩阵乘法 && 快速幂)
		http://acm.hdu.edu.cn/showproblem.php?pid=5667 这题的关键是处理指数,因为最后结果是a^t这种的,主要是如何计算t. 发现t是一个递推式,t(n) = c ... 
随机推荐
- RPC一般指远程过程调用协议
			RPC一般指远程过程调用协议 RPC(Remote Procedure Call)—远程过程调用,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议.RPC协议假定某些传输协议 ... 
- 怎样理解 MVVM ( Model-View-ViewModel ) ?
			MVVM 的 产生 / 实现 / 发展 可以写一篇很长的博客了, 这里仅写一下个人对 MVVM的一些肤浅的认识. 1. 在 没有 MVVM 之前, 前端可以说是 jQuery一把梭 , jQuery ... 
- 《深入实践C++模板编程》之三——模板参数类型详解
			非类型模板参数 和 模板型模板参数 整数以及枚举类型:指向对象或者函数的指针:对对象或函数的引用:指向对象成员的指针.统称为非类型模板参数. 模板型模板参数,是指模板参数还可以是一个模板. 1.整 ... 
- 开发工具idea
			https://blog.csdn.net/mashuai720/article/details/79389314 
- BZOJ4241历史研究题解--回滚莫队
			题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=4241 分析 这题就是求区间权值乘以权值出现次数的最大值,一看莫队法块可搞,但仔细想想,莫 ... 
- vue项目打包文件配置(vue-clli3)
			练手项目完结打包的时候遇到一些问题,特此记录 先贴我的vue.config.js文件的代码(vue-cli3构建的项目默认是没有此文件的,需手动添加)更多详细配置参考官方配置文档,我的项目不大不小,这 ... 
- 微信小程序iOS下拉白屏晃动,坑坑坑
			感觉ios的小程序每个页面都可以下拉出现白屏 有时页面带有滑动的属性会跟着晃动,体验不是很好 解决办法: 先禁止页面下拉 <config> { navigationBarTitleText ... 
- 【Spring Cloud】 总结
			一.Spring Cloud简介 简单来说,Spring Cloud 就是致力于分布式系统.微服务等的一套在目前非常火热的框架.但它的本身也是一系列框架的有序集合(由多个模块组成). 相比较于Dubb ... 
- Delphi WriteFile函数
- 05.Zabbix自动化监控
			1.Zabbix自动发现(被动) 网络发现官方手册 网络发现由两个阶段组成:发现discovery和动作actions 1.单击配置->自动发现->启动默认的Local network 2 ... 
