【题目链接】

http://www.lydsy.com/JudgeOnline/problem.php?id=3884

【题意】

求2^2^2… mod p

【思路】

设p=2^k * q+(1/0),使q为一个奇数

  第二项如果是1,mod 1 为0可以忽略。

则我们求:

2^2^2… mod p

=2^k*(2^(2^2…-k) mod q)

因为q是奇数所以与2互质,根据欧拉定理:

a^phi(p) mod p=1,(a,p)=1

转化为:

2^k*(2^(2^2…mod phi(p) – k mod phi(p)))

对于前一项可以递归求解,子问题为solve(phi(p)),递归边界为p=1,此时返回0。

【代码】

  1. #include<cmath>
  2. #include<cstdio>
  3. #include<cstring>
  4. using namespace std;
  5.  
  6. typedef long long ll;
  7. const int N = 1e5+;
  8.  
  9. ll pow(ll a,ll p,ll mod)
  10. {
  11. ll ans=;
  12. while(p)
  13. {
  14. if(p&) ans=(ans*a)%mod;
  15. a=(a*a)%mod; p>>=;
  16. }
  17. return ans;
  18. }
  19. ll phi(ll x)
  20. {
  21. ll ans=x;
  22. for(int i=;i*i<=x;i++) if(x%i==)
  23. {
  24. ans=ans/i*(i-);
  25. while(x%i==) x/=i;
  26. }
  27. if(x>) ans=ans/x*(x-);
  28. return ans;
  29. }
  30.  
  31. int n,T,P;
  32.  
  33. ll solve(ll p)
  34. {
  35. if(p==) return ;
  36. int k=;
  37. while(~p&) p>>=,k++;
  38. ll pi=phi(p);
  39. ll ans=solve(pi);
  40. ans=(ans+pi-k%pi)%pi;
  41. ans=pow(,ans,p)%p;
  42. return ans<<k;
  43. }
  44.  
  45. int main()
  46. {
  47. scanf("%d",&T);
  48. while(T--)
  49. {
  50. scanf("%d",&P);
  51. printf("%lld\n",solve(P));
  52. }
  53. return ;
  54. }

P.S.题解抄的PoPoQQQ的,自己又叙述了一遍而已

bzoj 3884 上帝与集合的正确用法(递归,欧拉函数)的更多相关文章

  1. BZOJ3884 上帝与集合的正确用法(欧拉函数)

    设f(n)为模n时的答案,由2k mod n=2k mod φ(n)+φ(n) mod n(并不会证),且k mod φ(n)=f(φ(n)),直接就可以得到一个递推式子.记搜一发即可. #inclu ...

  2. bzoj 3884 上帝与集合的正确用法 指数循环节

    3884: 上帝与集合的正确用法 Time Limit: 5 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description   根据一些 ...

  3. BZOJ 3884 上帝与集合的正确用法

    Description 根据一些书上的记载,上帝的一次失败的创世经历是这样的: 第一天, 上帝创造了一个世界的基本元素,称做"元". 第二天, 上帝创造了一个新的元素,称作&quo ...

  4. 【数学】[BZOJ 3884] 上帝与集合的正确用法

    Description 根据一些书上的记载,上帝的一次失败的创世经历是这样的: 第一天, 上帝创造了一个世界的基本元素,称做“元”. 第二天, 上帝创造了一个新的元素,称作“α”.“α”被定义为“元” ...

  5. BZOJ 3884 上帝与集合的正确用法(扩展欧拉定理)

    Description   根据一些书上的记载,上帝的一次失败的创世经历是这样的: 第一天, 上帝创造了一个世界的基本元素,称做“元”. 第二天, 上帝创造了一个新的元素,称作“α”.“α”被定义为“ ...

  6. BZOJ 3884: 上帝与集合的正确用法 [欧拉降幂]

    PoPoQQQ大爷太神了 只要用欧拉定理递归下去就好了.... 然而还是有些细节没考虑好: $(P,2) \neq 1$时分解$P=2^k*q$的形式,然后变成$2^k(2^{(2^{2^{...}} ...

  7. BZOJ.3884.上帝与集合的正确用法(扩展欧拉定理)

    \(Description\) 给定p, \(Solution\) 欧拉定理:\(若(a,p)=1\),则\(a^b\equiv a^{b\%\varphi(p)}(mod\ p)\). 扩展欧拉定理 ...

  8. 解题:BZOJ 3884 上帝与集合的正确用法

    题面 好久以前写的,发现自己居然一直没有写题解=.= 扩展欧拉定理:在$b>φ(p)$时有$a^b \equiv a^{b\%φ(p)+φ(p)}(mod$ $p)$ 然后每次递归那个$a^{b ...

  9. BZOJ 3884: 上帝与集合的正确用法 扩展欧拉定理 + 快速幂

    Code: #include<bits/stdc++.h> #define maxn 10000004 #define ll long long using namespace std; ...

随机推荐

  1. centos下hadoop2.6.0集群搭建详细过程

    一 .centos集群环境配置 1.创建一个namenode节点,5个datanode节点 主机名 IP namenodezsw 192.168.129.158 datanode1zsw 192.16 ...

  2. jQuery编程基础精华03(RadioButton操作,事件,鼠标)

    RadioButton操作 取得RadioButton的选中值,被选中的radio只有一个值,所以直接用val()  $('#btn1').click(function () {           ...

  3. SELinux开启与关闭

    SELinux是「Security-Enhanced Linux」的简称,是美国国家安全局「NSA=The National Security Agency」 和SCC(Secure Computin ...

  4. 内存泄露了么: Handlers & Inner Classes

    看到一篇关于handler和匿名类关于内存泄露的文章,觉得不错,充分发挥拿来主义,先放这儿看着! From:http://www.androiddesignpatterns.com/2013/01/i ...

  5. getpeername

    定义: int getpeername(int s, struct sockaddr *name, socklen_t *namelen); 描述: 获取socket的对方地址   得到对方的地址 s ...

  6. Objective-C命名编写规范

    There are only two hard things in Computer Science: cache invalidation and naming things. 在计算机科学中只有两 ...

  7. SQL中存储过程和自定义函数的区别

    存储过程:     存储过程可以使得对数据库的管理.以及显示关于数据库及其用户信息的工作容易得多.存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理.存储过程存储在 ...

  8. 【转载】Java中如何写一段内存泄露的程序 & ThreadLocal 介绍和使用

    可以参考这段文章: link A1:通过以下步骤可以很容易产生内存泄露(程序代码不能访问到某些对象,但是它们仍然保存在内存中): 上文中提到了使用ThreadLocal造成了内存泄露,但是写的不清不楚 ...

  9. org.hibernate.HibernateException: Could not parse configuration: /hibernate.cfg.xml

    org.hibernate.HibernateException: Could not parse configuration: /hibernate.cfg.xml at org.hibernate ...

  10. hdu4939 动态规划

    经典动态规划 无需单独枚举最后红塔的数量,因为对于dp[i][j],对于红塔的影响仅局限于i,j两个变量,与其前面塔排列无关,故二维动态规划即可. #include <cstdio> #i ...