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(1N1000000)
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

 

目录
打赏
0
0
0
0
57
分享
相关文章
阿里云无影云电脑(原云桌面)详细介绍
阿里云无影云电脑(原云桌面)详细介绍,阿里云推出无影云电脑,很多用户不清楚云电脑是什么,云电脑是一种安全高效的云上桌面服务,一般用于企业办公。云电脑支持快速便捷的桌面环境创建、部署、统一管控与运维。企业选择云电脑无需前期传统硬件投资,云电脑可以快速构建安全、高性能、低成本的企业桌面办公体系。阿里云百科来详细说下什么是无影云电脑以及云电脑和传统PC、VDI之间的区别
886 3
鲲鹏CPU架构分析1:高性能处理器的存储器组织与片上互联
为了使处理器的处理能力得到充分发挥,存储系统必须能够提供与处理器性能相匹配的存储器带宽。 因此,处理器与主存储器之间的速度差距一直是处理器结构设计中必须考虑的问题。由于处理器内的核心数目增多,并且各核心采用共享存储器结构进行信息交互,对主存的访问需求进一步增加,在单处理器时代面临的存储墙问题依然存在,而且问题更加严重。 故必须针对多核处理器进行相应的存储结构设计,并解决好存储系统的效率问题。
938 0
鲲鹏CPU架构分析1:高性能处理器的存储器组织与片上互联
微信课程表小程序(0基础教你用,从入门到发布)
1.效果图: 2.准备工具: 3.下载代码 4.部署项目 1.打开微信小程序: 2.AppID查看方式: 3.拿出你的小手机扫码、 5.修改课程 6.项目发布
微信课程表小程序(0基础教你用,从入门到发布)
ecs 服务器的初次使用
大一期间,在老师的指导下逐渐了解熟悉并运用ECS服务器
ecs 服务器的初次使用
华为、阿里、小米都在用的全屋智能技术
随着物联网技术以及5G技术的高速发展,家电、安防、家居等相关领域大厂相继入局,曾经不敢想象的联动场景开始走进我们的生活,10年前,你或许不能想象用语音控制家电,窗帘,但今天你只要对着智能音箱说一句话就能搞定了。本文将带你逐一盘点那些在家庭中使用到的物联网技术。
325 15
华为、阿里、小米都在用的全屋智能技术
直给式的技术写作思维
本文通过一个技术文档写作案例,分享个人在技术写作上的一些思考,如标题所示,主要介绍自己在技术文档写作实践中总结的“直给式”写作思维的运用,希望对有产品文档或API文档写作需求的PD、开发同学有所帮助。
652 0
直给式的技术写作思维
【GTC 22】PaiSparse:面向深度学习的稀疏算子库
随着越来越多超大语言模型的出现,如何将这些超大语言模型在实际业务中部署落地成为了一个急需解决的问题。这些超大语言模型拥有百亿千亿甚至于万亿的参数,如此巨大的参数使得无法将超大模型直接部署在单张卡上,而需要几个甚至几十个 GPU 参与模型推理,会消耗非常大的计算资源。然而一些常用的模型优化技术如剪枝和量化虽然能够有效的降低模型大小,但是这些算法却很难在保证精度的情况下达到较大的压缩率。因此我们选择了非结构化稀疏来压缩超大语言模型,从而使得他们能够在保证精度的情况下达到较高的压缩率。
Java常用对象后缀命名随记
面对java对象的命名,有时候会忘记取什么名字好点,以什么标准为主,所以就做下简单的记录,不断迭代
815 0