码迷,mamicode.com
首页 > 编程语言 > 详细

hihocoder1330 数组重排

时间:2017-09-09 22:27:28      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:return   its   题解   log   nbsp   main   amp   max   答案   

题意:一个数组,每次把i位置的数移到pi位置,问要几次可以将数组重新排列回来

题解:计算每个数的周期,所有数的周期的lcm就是答案,复杂度O(n*n),一个循环里面的数周期都是一样的,标记一下,复杂度o(n)

#include <bits/stdc++.h>
#define maxn 110
#define ll long long
using namespace std;
ll a[maxn], dir[maxn];
map<ll,ll>mp;
int main(){
    ll n, t, num=0, ans=1;
    scanf("%lld", &n);
    for(ll i=1;i<=n;i++) scanf("%lld", &a[i]);
    for(ll i=1;i<=n;i++){
        num = 0;t = a[i];
        if(dir[t] == 1) continue;
        mp.clear();
        while(!mp[t]){
            mp[t] = 1;
            t = a[t];
            dir[t] = 1;
            num++;
        }
        ans = ans*num/__gcd(ans, num);
    }
    printf("%lld\n", ans);
    return 0;
}

 

hihocoder1330 数组重排

标签:return   its   题解   log   nbsp   main   amp   max   答案   

原文地址:http://www.cnblogs.com/Noevon/p/7499350.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!