2015百度之星 大搬家

简介: 大搬家   Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem Description 近期B厂组织了一次大搬家,所有人都要按照指示换到指定的座位上。

大搬家

 

Time Limit: 2000/1000 MS (Java/Others)
Memory Limit: 65536/65536 K (Java/Others)
Problem Description
近期B厂组织了一次大搬家,所有人都要按照指示换到指定的座位上。指示的内容是坐在位置$i$上的人要搬到位置$j$上。现在B厂有$N$个人,一对一到$N$个位置上。搬家之后也是一一对应的,改变的只有位次。 在第一次搬家后,度度熊由于疏忽,又要求大家按照原指示进行了一次搬家。于是,机智的它想到:再按这个指示搬一次家不就可以恢复第一次搬家的样子了。于是,B厂史无前例的进行了连续三次搬家。 虽然我们都知道度度熊的“机智”常常令人堪忧,但是不可思议的是,这回真的应验了。第三次搬家后的结果和第一次的结果完全相同。 那么,有多少种指示会让这种事情发生呢?如果两种指示中至少有一个人的目标位置不同,就认为这两种指示是不相同的。
Input
第一行一个整数$T$,表示T组数据。 每组数据包含一个整数$N(1 \leq N \leq 1 000 000)$。
Output
对于每组数据,先输出一行 Case #i: 然后输出结果,对$1000000007$取模。
Sample Input
2
1
3
Sample Output
Case #1:
1
Case #2:
4

第二个样列的解释:

1 1
2 2
3 3

1 2
2 3
3 1

1 3
2 1
3 2

1 3
2 2
3 1

题目意思:给你一个n,让你找1~n的对应关系组的数目,这个对应关系组满足:执行这个对应关系组三次后,又回到了初始状态。

 

Problem's Link:   http://bestcoder.hdu.edu.cn/contests/contest_showproblem.php?cid=584&pid=1001


 

Mean: 

analyse:

找规律,必须两次就恢复回去,必须一对一对换,或两对两对换等。

Time complexity: O(n)

 

Source code: 

 

/*
* this code is made by crazyacking
* Verdict: Accepted
* Submission Date: 2015-05-23-18.04
* Time: 0MS
* Memory: 137KB
*/
#include <queue>
#include <cstdio>
#include <set>
#include <string>
#include <stack>
#include <cmath>
#include <climits>
#include <map>
#include <cstdlib>
#include <iostream>
#include <vector>
#include <algorithm>
#include <cstring>
#define  LL long long
#define  ULL unsigned long long
using namespace std;
const int mod=1000000007;
const int MAXN=1000010;
ULL ans[MAXN];
void pre()
{
        ans[1]=1,ans[2]=2;
        for(int i=3;i<MAXN;++i)
        {
                ans[i]=ans[i-1]+(i-1)*ans[i-2];
                ans[i]%=mod;
        }
}
int main()
{
        int t;
        pre();
        scanf("%d",&t);
        int Cas=1;
        while(t--)
        {
                int n;
                scanf("%d",&n);
                printf("Case #%d:\n",Cas++);
                printf("%d\n",ans[n]);
        }
        return 0;
}
/*

*/
View Code

 

目录
相关文章
|
3月前
|
前端开发
在线一键生成国庆红旗风头像网站源码
抖音微信超火国庆节国旗头像生成源码,静态页前端生成速度超快!源码直接上传到服务器即可使用。
49 0
在线一键生成国庆红旗风头像网站源码
百度之星之D:共同狂欢
百度2005年8月5日上市时,在北京和纳斯达克的同学们每一个小时整点时就会通一次电话,对一下表,确认一切相关活动都精确同步。但是要注意,在两边的同学位于不同的时区,在夏时制时,两地时差12小时,因此,每次对表都需要做一下时区转换。你来帮我们完成这个有点麻烦的工作吧。
159 0
百度之星之D:共同狂欢
|
算法
百度之星之J:百度的新大厦
描述 继百度搜索框大厦之后,百度又于2012年初在深圳奠基了新的百度国际大厦,作为未来百度国际化的桥头堡。不同于百度在北京的搜索框大厦,新的百度国际大厦是一栋高楼,有非常多的楼层,让每个楼中的电梯都能到达所有楼层将是一个极为不明智的设计。
187 0
|
移动开发 定位技术 数据格式
百度之星之I:地图的省钱计划
百度地图有自己的一套坐标系(你可以把它看作一个笛卡尔坐标系),在这套坐标系里,一个标准单位为1km。而在这坐标系上针对地理信息进行标注的数据,大多数时候是通过购买的方式完成的。为了节约数据更新的成本,数据组里的鑫哥想出了一个好主意——自己测数据。
141 0
百度之星之F:百科蝌蚪团
百度百科有一支神奇的队伍,他们叫自己“百科蝌蚪团”。为了更好的让蝌蚪团的成员们安排工作,百度百科的运营团队定出了一个24小时制的时间表。
336 0
阿里云市场头条投稿指南
阿里云市场头条投稿指南
5339 0
|
人工智能
今晚直播预告:“创客天下·杭向未来”(美国站)海选第一期
本次美国站海选(第一期)由良仓加速器、纽约来易加速器共同呈现,邀请多位重量级嘉宾和优秀项目,整合各类创新创业要素,旨在为海外项目搭建对接交流的平台。
搬家到云栖啦
我的博客即将入驻“云栖社区”,诚邀技术同仁一同入驻。
856 0
|
Web App开发 安全 数据安全/隐私保护
【阿里聚安全·安全周刊】阿里云9大新年礼|正式上线移动直播问答解决方案
阿里安全周刊第八十一期,分享本周移动安全热点和技术知识。
4503 0
自媒体平台资讯06:网易有网易号,有网易公开课自媒体,现在又有网易有道号?
舍得哥前段时间分享过网易公开课自媒体平台,不知道身边的朋友入住了没,要不再去回顾下? 这是网易公开课自媒体的后台截图 总共发布两篇文章,貌似流量不行啊,尴尬了,不能怪平台,怪自己的文章不适合那个平台 网易现在有好几个自媒体平台了,网易号,网易云自媒体,网易公开课自媒体,现在又有网易有道号自媒体。
1304 0