AtCoder Grand Contest 031 (AGC031) D - A Sequence of Permutations 其他
原文链接https://www.cnblogs.com/zhouzhendong/p/AGC031D.html
前言
比赛的时候看到这题之后在草稿纸上写下的第一个式子就是
$$f(p,q) = pq^{-1}$$
然后就再也没有改过。
发现了一堆奇奇怪怪的性质可是一直没有用。
直到官方题解出来的时候:
$$\Huge f(p,q) = qp^{-1}$$
题解
我们可以把前面的几个 $a_i$ 写出来。
$$\begin {eqnarray*}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}ppq^{-1}\\a_7&=&qp^{-1}q^{-1}pqpq^{-1}\\a_8&=&qp^{-1}q^{-1}pqp^{-1}qpq^{-1}\end{eqnarray*}$$
设
$$A = qp^{-1}q^{-1}p$$
则可以归纳证明:
$$\forall i>6, a_i = Aa_{i-6} A^{-1}$$
于是直接算一下置换 $A$ 的复合幂就好了。
算复合幂只要写成轮换的形式就可以做到时间复杂度 $O(n)$ ,我偷懒写了 $O(n\log n)$ 的快速幂。
代码
- #pragma GCC optimize("Ofast","inline")
- #include <bits/stdc++.h>
- #define clr(x) memset(x,0,sizeof (x))
- #define For(i,a,b) for (int i=a;i<=b;i++)
- #define Fod(i,b,a) for (int i=b;i>=a;i--)
- #define pb push_back
- #define mp make_pair
- #define fi first
- #define se second
- #define _SEED_ ('C'+'L'+'Y'+'A'+'K'+'I'+'O'+'I')
- #define outval(x) printf(#x" = %d\n",x)
- #define outvec(x) printf("vec "#x" = ");for (auto _v : x)printf("%d ",_v);puts("")
- #define outtag(x) puts("----------"#x"----------")
- #define outarr(a,L,R) printf(#a"[%d...%d] = ",L,R);\
- For(_v2,L,R)printf("%d ",a[_v2]);puts("");
- using namespace std;
- typedef long long LL;
- typedef vector <int> vi;
- LL read(){
- LL x=0,f=0;
- char ch=getchar();
- while (!isdigit(ch))
- f|=ch=='-',ch=getchar();
- while (isdigit(ch))
- x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
- return f?-x:x;
- }
- const int N=100005;
- int n,k;
- vi p,q,ip,iq,a[10];
- vi Inv(vi A){
- vi B(n);
- For(i,0,n-1)
- B[A[i]]=i;
- return B;
- }
- vi Mul(vi A,vi B){
- vi C(n);
- For(i,0,n-1)
- C[i]=A[B[i]];
- return C;
- }
- vi Pow(vi x,int y){
- vi ans;
- For(i,0,n-1)
- ans.pb(i);
- for (;y;y>>=1,x=Mul(x,x))
- if (y&1)
- ans=Mul(ans,x);
- return ans;
- }
- int main(){
- n=read(),k=read();
- For(i,1,n)
- p.pb(read()-1);
- For(i,1,n)
- q.pb(read()-1);
- ip=Inv(p),iq=Inv(q);
- a[1]=p,a[2]=q;
- For(i,3,6)
- a[i]=Mul(a[i-1],Inv(a[i-2]));
- int len=(k-1)/6;
- vi cir=Pow(Mul(q,Mul(ip,Mul(iq,p))),len);
- vi rem=a[k-len*6];
- vi res=Mul(cir,Mul(rem,Inv(cir)));
- For(i,0,n-1)
- printf("%d ",res[i]+1);
- return 0;
- }
AtCoder Grand Contest 031 (AGC031) D - A Sequence of Permutations 其他的更多相关文章
- AtCoder Grand Contest 031 简要题解
AtCoder Grand Contest 031 Atcoder A - Colorful Subsequence description 求\(s\)中本质不同子序列的个数模\(10^9+7\). ...
- AtCoder Grand Contest 031题解
题面 传送门 题解 比赛的之后做完\(AB\)就开始发呆了--简直菜的一笔啊-- \(A - Colorful\ Subsequence\) 如果第\(i\)个字母选,那么它前面任意一个别的字母的选择 ...
- Atcoder Grand Contest 031 D - A Sequence of Permutations(置换+猜结论)
Atcoder 题面传送门 & 洛谷题面传送门 猜结论神题. 首先考虑探究题目中 \(f\) 函数的性质,\(f(p,q)_{p_i}=q_i\leftarrow f(p,q)\circ p= ...
- AtCoder Grand Contest 031 B - Reversi
https://atcoder.jp/contests/agc031/tasks/agc031_b B - Reversi Time Limit: 2 sec / Memory Limit: 1024 ...
- AtCoder Grand Contest 031 B - Reversi(DP)
B - Reversi 题目链接:https://atcoder.jp/contests/agc031/tasks/agc031_b 题意: 给出n个数,然后现在你可以对一段区间修改成相同的值,前提是 ...
- UPC个人训练赛第十五场(AtCoder Grand Contest 031)
传送门: [1]:AtCoder [2]:UPC比赛场 [3]:UPC补题场 参考资料 [1]:https://www.cnblogs.com/QLU-ACM/p/11191644.html B.Re ...
- Atcoder Grand Contest 024 E - Sequence Growing Hard(dp+思维)
题目传送门 典型的 Atcoder 风格的计数 dp. 题目可以转化为每次在序列中插入一个 \([1,k]\) 的数,共操作 \(n\) 次,满足后一个序列的字典序严格大于前一个序列,问有多少种操作序 ...
- AtCoder Grand Contest 003
AtCoder Grand Contest 003 A - Wanna go back home 翻译 告诉你一个人每天向哪个方向走,你可以自定义他每天走的距离,问它能否在最后一天结束之后回到起点. ...
- AtCoder Grand Contest 012
AtCoder Grand Contest 012 A - AtCoder Group Contest 翻译 有\(3n\)个人,每一个人有一个强大值(看我的假翻译),每三个人可以分成一组,一组的强大 ...
随机推荐
- vue-cli 项目踩坑 npm install 时出错
1.报错如下: 2.此时你执行npm run dev / npm run build 会报错如下 npm ERR! code ELIFECYCLEnpm ERR! errno 1npm ERR! v ...
- Linux,Ubuntu,Mint 环境下 navicat 乱码问题
1. 官方下载好以后,进入目录 执行 ./start_navicat 可以启动软件. 2. 如果有乱码,首先,使用编辑器打开 start_navicat ,比如 vim start_navicat ...
- boto3库限速
# -*- coding: utf-8 -*- import boto3 from boto3.s3.transfer import TransferConfig # from s3transfer. ...
- VMware 安装Linux系统 CentOS
VMware 安装Linux系统 CentOS 1. 下载镜像系统 centos镜像下载地址:https://www.centos.org/download/ 选择DVD下载即可 linux各版本下 ...
- DirectX11--实现一个3D魔方(1)
前言 可以说,魔方跟我的人生也有一定的联系. 在高中的学校接触到了魔方社,那时候的我虽然也能够还原魔方,可看到大神们总是可以非常快地还原,为此我也走上了学习高级公式CFOP的坑.当初学习的网站是在魔方 ...
- JN_0008:win下通过cmd进入指定目录
1,WIN+R,调出运行命令窗口,并输入CMD,回车确认运行 2,先进入盘符,如: d: 3,再进入盘符下的指定目录,如: cd test 4,一次性进入指定目录(要用到 /d 命令): ...
- sqlyog连接mysql8.0
1.本人安装的是mysql8.0社区版,安装包名称:mysql-installer-community-8.0.12.0.msi,可自行到官网下载. 2.安装完成后用sqlyog连接数据库出现密码乱码 ...
- 一个老鸟发的公司内部整理的 Android 学习路线图
基础工具部分: 中文手册,我猜测是Maven中文手册,可是我并没有找到这样的资源,欢迎知道的朋友告诉我: Android部分有 『第三方库集合』,我没能找到资源地址: 书籍我大多是给的豆瓣链接,如果觉 ...
- 问题:强制关闭Redis快照导致不能持久化
运行Redis发生错误:"MISCONF Redis is configured to save RDB snapshots, but is currently not able to pe ...
- python3三角函数
三角函数 acos(x) 返回x的反余弦弧度值. asin(x) 返回x的反正弦弧度值. atan(x) 返回x的反正切弧度值. atan2(y, x) 返回给定的 X 及 Y 坐标值的反正切 ...