一模 (2) day1
第一题:
题目大意:
设 2n 张牌分别标记为 1, 2, ..., n, n+1, ..., 2n,初始时这 2n 张牌按其标号从小到大
排列。经一次洗牌后,原来的排列顺序变成 n+1, 1, n+2, 2, ..., 2n, n。即前 n 张牌被放到
偶数位置 2, 4, ..., 2n,而后 n 张牌被放到奇数位置 1, 3, ..., 2n-1。可以证明对于任何一
个自然数 n,经过若干次洗牌后可恢复初始状态。现在你的的任务是计算对于给定的 n 的值(n≤10^5 ),
最少需要经过多少次洗牌可恢复到初始状态。
解题过程:
1.模拟绝对超时,然后就开始找规律,对于当前位置是x的数,如果x<=n,下一次就会跑到2*x的位置。否则会跑到(2*x-1) mod (2*n)的位置。
2.手工模拟了下,感觉只要一个数回到原位其他数也就回来了,那么取位置1,按照规则不断模拟,知道回到1为止,然后就糊里糊涂AC了。
3.考后怎么也想不明白为什么只要任意取一个数就好,结果TMD 找到了一个反例:n=10的时候;
如果一开始取位置1的数,那么它的位置变化是 1->2->4->8->16->11->1 那么答案就是6。
如果一开始取位置3的数,那么它的位置变化是 3->6->12->3->6->12->3
可以发现第3次洗牌后,位置3的数回到了原位,但是位置1的数还没有,如果一开始选了位置3的数,那么答案就会是3。
难道只要一开始选位置1的数就能AC??
http://tieba.baidu.com/p/3246473319 贴吧大神给了解释。 祝热心的大神rp++。
首先一个位置为x的数,变换一次后,位置变成了 (2*x) mod (2*n+1);
如果初始位置为x的数变换t次后回到原位,那么 有 x * 2^t ≡ x (mod (2n+1)) 下面的证明需要一些同余式的知识。
A: 如果gcd(x,2n+1)= 1 , 则有 2^t1 ≡ 1 ( mod (2n+1) )
B:如果gcd (x, 2n+1)> 1 , 则有 2^t2 ≡ 1 ( mod (2n+1)/gcd(x,2n+1) );
可以证明 t1 必定是 t2 的倍数,证明如下:(t1,t2都是符合要求的最小的那个)
设 t1=a*t2 + b (0<=b<t2) , (2n+1)/gcd(x,2n+1)=m
A: 2^t2 ≡ 1 (mod m) -> 2^(a*t2) ≡ 1 (mod m)
B: 2^t1 ≡ 1 (mod (2n+1)) -> 2^(a*t2 + b) ≡ 1 (mod (2n+1)) -> 2^(a*t2 + b) ≡ 1 (mod m) (因为2n+1是m的倍数);
根据 A,B 可以得到 2^b ≡ 1 (mod m) ,而 b < t2 因此b=0,否则与前面 “t1,t2都是符合要求的最小的那个”矛盾,因此b=0; 所以 t1= a * t2 , 即 t1 是 t2 的倍数;
而我们要求的最终答案是 所以 t 的最小公倍数 , 因此 x 与 2n+1 互质的时候取得t就是答案,这也就解释了上面为什么取1 就能得到答案 而取 3 就挂掉了。
求解答案只要求 2^t ≡ 1 (mod 2n+1) 的最小解;
首先 phi(2n+1) 是 满足条件的。
那么答案 必定是 2n+1 的约数, 证明 同上 ,把ans看成 t2, 把 phi(2n+1)看成 t1, 那么同理 t1=a*t2 ;
所以 只要 枚举 phi(2n+1)的约数,用快速幂判断是否符合即可。
复杂度进一步从O(ans) 降到了 O(sqrt(n)*log(n));
另外如果只要证明为什么1回到原位,那么所有数都回到原位的话,有个很简单的证明, 设1 经过t次回到 原位 ,那么 1^t ≡ 1 (mod (2n+1)); 两边同时乘一个x,那么有1^t * x ≡ x (mod (2n+1)) ,也就是 其他数也 回到了原位。
第二题:
题目大意:老题了,合并果子。。 复习了下堆水过。
第三题:
题目大意:解数独。
解题过程:
1.dfs爆搜+hash,倒着搜会更快。最慢0.96s,差点挂掉了。见NOIP2009靶形数独,我的解题报告。http://www.cnblogs.com/vb4896/p/3881250.html
2.dancing link,研究ing。。标程所有数据0ms 秒杀啊。
一模 (2) day1的更多相关文章
- 二模 (16) day1&day2
第一题:题目大意: 数列a[0]=a[1]=1, a[n]=a[n-2]*a[n-1]*n,求a[n]的因子个数 mod 1000000007. n<=1000000 解题过程: 1.递推式还 ...
- 一模 (1) day1
第一题:(水题) 题目大意:求出n个 X% (X是小于等于2位的整数) 的乘积,去掉末尾的0: 解题过程: 1.直接 把整数乘好,然后确定小数点的位置,去掉多余的0 输出即可. 第二题:(搜索题) ...
- 二模 (15)day1
第一题: 题目大意: 有两个长度为N的序列A和B,在A和B中各任取一个数相加可以得到N2个和,求这N2个和中最小的N个. 解题过程: 1.这题是刘汝佳<<训练指南>>上的一道经 ...
- 二模 (13)day1
第一题: 题目大意: N个发射站排成一排,求每个发射站左右第一个比它高的发射站. N<=1000000 解题过程: 1.前几天做poj的时候刚好在discuss里看到有一个神奇的东东叫单调栈,正 ...
- 二模 (12) day1
第一题: 题目大意: 求由N个1,M个0组成的排列的个数,要求在排列的任意一个前缀中,1的个数不少于0的个数.N,M<=5000. 解题过程: 1.看到N,M的范围就明确肯定不会是dp,因为起码 ...
- 二模 (11) day1
第一题: 题目大意:用邻接矩阵给出一棵树(边权非负)上N个节点相互之间的最短路距离,求这棵树所有边权的和. 解题过程: 1.暂时还没想出来,待AC. 第二题: 题目大意:给出一些单词,然后建立Trie ...
- 二模 (9)day1
第一题: 题目大意: 给出一个n位01串,要么不动它,要么把它删掉一个字符,要么插入一个字符(0或1),要么把一个1变成0,.使得有1的位置号的总和是n+1的倍数,或者是0. 解题过程: 1.直接枚举 ...
- 二模 (10)day1
第一题: 题目描述: 一个阅览室每天都要接待大批读者.阅览室开门时间是0,关门时间是T.每位读者的到达时间都不一样,并且想要阅读的刊物不超过5本.每位读者心里对自己想看的刊物都有一个排位,到达之后他会 ...
- 二模 (8) day1
第一题: 题目大意: 梦幻城市每年为全市高中生兴办一次运动会.为促使各校同学之间的交流,采用特别的分队方式:每一个学校的同学,必须被均匀分散到各队,使得每一队中该校的人数皆相同.为增加比赛的竞争性,希 ...
- 二模 (7) day1
第一题: 题目大意: 给出数轴上N棵树的坐标和高度,如果两棵树之间的距离小于其中一颗树的高度,那么就有树会被挡住.因此要把一些树砍矮一点.求砍树的总高度最小值. N<=100000; 解题过程: ...
随机推荐
- Java编程思想学习笔记_2(继承和多态)
静态初始化: 静态初始化只在必要的时刻进行.(即当程序需要加载类进入内存的时候,执行静态初始化.静态变量和静态代码块的初始化顺序,按照在代码中声明的顺序老执行.例如:如果要执行某个public类,那么 ...
- (八)shell中的循环结构
1.for循环(1)要求:能看懂.能改即可.不要求能够完全不参考写出来.因为毕竟嵌入式并不需要完全重新手写shell,系统管理员(服务器运维人员,应用层系统级管理开发的才需要完全掌握shell) 这里 ...
- TortoiseSvn
TortoiseSVN 是svn版本控制系统的一个免费开源客户端,它是svn版本控制的 Windows 扩展.可以使你避免使用枯燥而且不方便的命令行.它完全嵌入 Windows Explorer,使用 ...
- active developer path ("") does not exist
pod update --verbose --no-repo-update 出现的错误. 解决:在终端中修改你的CommandLine Tools的位置: xcode-select -switch / ...
- hdu 5317 RGCDQ(前缀和)
题目链接:hdu 5317 这题看数据量就知道需要先预处理,然后对每个询问都需要在 O(logn) 以下的复杂度求出,由数学规律可以推出 1 <= F(x) <= 7,所以对每组(L, R ...
- sqlserver 2008 服务器拒绝连接;拒绝访问指定的数据库
sqlserver配置管理器----sqlserver网络配置 --- 启用 named pipes OK 由于之前的程序是SQL2000开发的,迁移到SQL20008出了这个问题. 二 和主题没有什 ...
- RAC 集群更换IP
RAC 集群更换 IP 主要分三步:停集群服务.配置服务器网络.修改集群配置.下面是同网段内更换 IP 示例.(r7.r8为服务器名称,orcl为ORACLE_SID,scanip为 scan 名称) ...
- 黑盒测试在App自动化测试中的应用
黑盒测试在App自动化测试中的应用 不废话,直接来. 先说说什么是黑盒测试 黑盒测试,这里就说的是app功能测试,之前看到一个介绍说,就是在测试中,把测试对象看作一个黑盒子.利用黑盒测试法进行动态测试 ...
- python操作mongodb之四cp数据库
from pymongo import MongoClient #连接数据库 client=MongoClient('192.168.30.252',27017) #获取现有数据库的名称 client ...
- Android相机开发那些坑
版权声明:本文由王梓原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/168 来源:腾云阁 https://www.qclou ...