时间限制 1s 空间限制 512MB

3.1 题目描述

“Geronimo∼”

时间还很多,让我们慢慢来。

不如听首开心的歌再看题?…… 算了,直接看题吧。

给定一个整数 n,以及一个 n 阶的排列 p 1 , p 2 , …, p n 。

我们定义重组过程如下:如果当前的排列是 a 1 , a 2 , …, a n ,经过一次重组,就会

变成 p a 1 , p a 2 , …, p a n 。

问一个排列至少要经过多少次重组才会恢复成重组前的状态。

由于答案可能很大,输出其对一个给定的正整数 q 取模的值即可。

3.2 输入格式

第一行两个正整数 n, q。

第二行一共 n 个整数,依次表示 p 1 , p 2 , …, p n 。

同一行相邻的数间用一个空格隔开。

3.3 输出格式

一行一个整数,表示答案对 q 取模的值。

3.4 样例输入

7 1000000207

2651347

3.5 样例输出

4

3.6 数据规模和约定

对于全部的数据,q ≤ 2 × 10 9

对于 10% 的数据,q = 1

对于另外 20% 的数据,n ≤ 9

6对于另外 40% 的数据,n ≤ 10 3

对于剩下 30% 的数据,n ≤ 5 × 10 5

【题解】

这道题就是找出每个点恢复初始状态的步数(或者称为找个环),再求出这些步数的最大公约数即可。

(然而我考试时打了个愚蠢的10分暴力)

但注意有几点优化:

1、一个环上所有点恢复初始状态的步数相同(解决TLE问题)

2、求一群数的最大公约数,可以一一找出每一对数,求出两个数的最大公约数,再用后一个数除掉(用前一个数的话就是改掉当前搜索的数,会wa7个点),最后把剩下的数连乘即可。(另一种思路是线性筛打表出素数,看每个数的质因子)

3、恢复初始状态的步数相同的点的步数可去重,这里我用的是map(和vis一样)。

#include<iostream>
#include<cmath>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<vector>
#include<map>
#define ll long long
#define re register
#define il inline
#define fp(i,a,b) for(re ll i=a;i<=b;i++)
#define fq(i,a,b) for(re ll i=a;i>=b;i--)
using namespace std;
ll a[500005]={},c[500005]={},total=0;
bool vis[500005]={};
map<ll,ll>b;
il ll gi()
{
re ll x=0;
re ll t=1;
re char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-') ch=getchar();
if(ch=='-') t=-1,ch=getchar();
while(ch>='0'&&ch<='9') x=x*10+ch-48,ch=getchar();
return x*t;
}
ll gcd(ll x,ll y)
{
if(y==0) return x;
return gcd(y,x%y);
}
int main()
{
freopen("geronimo.in","r",stdin);
freopen("geronimo.out","w",stdout);
ll n=gi(),q=gi();
if(q==1) {printf("0\n");return 0;}
fp(i,1,n)
a[i]=gi();
fp(i,1,n)
if(vis[i]==0)
{
ll j=a[i],sum=1;
while(j!=i) sum++,j=a[j];
j=a[i];
while(j!=i) vis[j]=1,j=a[j];
if(b[sum]==0) b[sum]=1,c[++total]=sum;
}
fp(i,1,total-1)
fp(j,i+1,total)
{
ll x=c[i],y=c[j];
if(x<y) swap(x,y);
ll r=gcd(x,y);
c[j]/=r;//beach,c[i]/=i会wa7个点,因为不能改当前数
}
ll ans=1;
fp(i,1,total)
ans=(1ll*ans*c[i])%q;
printf("%lld\n",ans);
fclose(stdin);
fclose(stdout);
return 0;
}

geronimo的更多相关文章

  1. Geronimo应用服务器和MySQL数据库服务器

    就是Web 2.0的全部,尽管该术语出现才几乎一年的时间,但现在好像只有烹饪杂志还没有加入到讨论Web 2.0未来出路的行列中.自从出现了里程碑式的文章"What Is Web 2.0:De ...

  2. Geronimo tomcat: 在 Apache Geronimo 插件体系中将 Apache Tomcat 这个优秀的 Web 容器整合至其中

    Apache Geronimo 灵活的插件体系将 Tomcat, OpenJPA, OpenEJB, ActiveMQ 等第三方组件集成至其中.本文从多角度介绍了在 Apache Geronimo 中 ...

  3. Geronimo 叛逆者: 使用集成软件包:Codehaus 的 Woodstox(转载)

    XML 解析器通常是高性能.健壮应用程序的关键.传统的 XML 解析技术包括文档对象模型(Document Object Model,DOM)和 Simple API for XML (SAX).现在 ...

  4. Apache Geronimo Remote Code Execute Vulnerability

    简介: Apache Geronimo 是 Apache 软件基金会的开放源码J2EE服务器,它集成了众多先进技术和设计理念. 这些技术和理念大多源自独立的项目,配置和部署模型也各不相同. Geron ...

  5. Java消息队列--ActiveMq 实战

    1.下载安装ActiveMQ ActiveMQ官网下载地址:http://activemq.apache.org/download.html ActiveMQ 提供了Windows 和Linux.Un ...

  6. 关于Karaf Container 4.0.7

            Karaf是Apache旗下的一个开源项目.Karaf同时也是一个基于OSGi的运行环境,Karaf提供了一个轻量级的OSGi容器,可以用于部署各种组件,应用程序.Karaf提供了很多 ...

  7. activemq和jms是种什么关系

    JMS是一个用于提供消息服务的技术规范,它制定了在整个消息服务提供过程中的所有数据结构和交互流程. 而activemq则是消息队列服务,是面向消息中间件(MOM)的最终实现,是真正的服务提供者. jm ...

  8. ActiveMQ入门

    ActiveMQ简介 概要 开源 JMS-compliant 消息中间件message-oriented middleware(MOM) 松耦合,相对于RPC的紧耦合 发送消息fire-and-for ...

  9. Deployment options

    Play applications can be deployed virtually anywhere: inside Servlet containers, as standalone serve ...

随机推荐

  1. Java基础(四)--接口和抽象类

    接口和抽象类能够体现OOP的抽象,而接口和抽象类也是日常开发中经常用到的 抽象方法: 抽象方法就是被abstract修饰的方法,只有声明,没有实现,也就是没有方法体 public abstract v ...

  2. PHP--选择排序

    <?php /** * 选择排序(从小到大)的思想:每一次从待排序的数据中选出最小的,放在待排序的起始位置. */ $arr = array(23, 42, 21, 8, 4, 2, 3, 1) ...

  3. Socket中BufferedReader.readLine()的阻塞特性导致的数据无法多次发送的问题

    https://blog.csdn.net/shenpibaipao/article/details/70236657

  4. 迷宫问题 POJ - 3984 (搜索输出路径)

    题目大意 题目不需要大意,poj居然还有中文题 鸣谢 特别鸣谢ljc大佬提供的方法!!! 解法 我们可能输出个最短路径的长度比较简单,但是输出最短路径真的是没有做过,这里有一种简单的方法 因为我们的d ...

  5. 转来的--轻松自动化---selenium-webdriver(python) (七)---定位iframe——转来的

    本节知识点: 多层框架或窗口的定位: switch_to_frame() switch_to_window() 智能等待: implicitly_wait() 对于一个现代的web应用,经常会出现框架 ...

  6. 运用循环求和( sum operation in python)

    1.for loop example 1: sum of 1+2+...+10 ********** >>> sum=0 >>> for x in [1,2,3,4 ...

  7. [luoguP2875] [USACO07FEB]牛的词汇The Cow Lexicon(DP)

    传送门 f[i] 表示前 i 个字符去掉多少个 的最优解 直接暴力DP ——代码 #include <cstdio> #include <cstring> #include & ...

  8. Codeforces Beta Round #91 (Div. 1 Only) E. Lucky Array

    E. Lucky Array Petya loves lucky numbers. Everybody knows that lucky numbers are positive integers w ...

  9. RCC 2014 Warmup (Div. 2) 蛋疼解题总结

    A. Elimination time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  10. noip模拟赛 蒜头君的树

    分析:这道题问的是树上整体的答案,当然要从整体上去考虑. 一条边对答案的贡献是这条边一端连接的点的个数*另一端连接的点的个数*边权,可以用一次dfs来统计答案,之后每次更改操作在原答案的基础上增减就好 ...