上帝与集合的正确用法

【问题描述】

【输入格式】

第一行一个T,接下来T行,每行一个正整数p,代表你需要取模的值。

【输出格式】

T行,每行一个正整数,为答案对p取模后的值。

【样例输入】

3
2
3
6

【样例输出】

0
1
4

【数据范围】

对于100%的数据,T<=1000,p<=10^7

题解:
 

①->②:把模数 p 拆成 2kq 的形式,其中 q 是奇数

②->③:

将上式左右同除以2k

不会同余的蒟蒻只能这么推了

③->④:

此时 q 是奇数,必定与 2n 互质

则套用欧拉定理

考虑一个数的 phi 必定比它本身的值小

那么如此递归下去模数会变为 1,则返回 0

回溯得到答案

  1. #include<cmath>
  2. #include<cstdio>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<iostream>
  6. #include<algorithm>
  7. using namespace std;
  8. int n;
  9. inline void Scan(int &x)
  10. {
  11. char c;
  12. bool o = false;
  13. while(!isdigit(c = getchar())) o = (c != '-') ? o : true;
  14. x = c - '';
  15. while(isdigit(c = getchar())) x = x * + c - '';
  16. if(o) x = -x;
  17. }
  18. int Phi(int x)
  19. {
  20. int ans = x;
  21. for(int i = ; i * i <= x; ++i)
  22. {
  23. if(!(x % i))
  24. {
  25. while(!(x % i)) x /= i;
  26. ans /= i, ans *= (i - );
  27. }
  28. }
  29. if(x ^ ) ans /= x, ans *= (x - );
  30. return ans;
  31. }
  32. int Pow(int x, int n, int mod)
  33. {
  34. int sum = ;
  35. while(n)
  36. {
  37. if(n & ) sum = (long long) sum * x % mod;
  38. x = (long long) x * x % mod;
  39. n >>= ;
  40. }
  41. return sum % mod;
  42. }
  43. int Work(int p)
  44. {
  45. if(p == ) return ;
  46. int k = ;
  47. while(!(p & )) p >>= , ++k;
  48. int phi = Phi(p);
  49. int s = (Work(phi) - k) % phi;
  50. if(s < ) s += phi;
  51. return Pow(, s, p) << k;
  52. }
  53. int main()
  54. {
  55. Scan(n);
  56. int p;
  57. for(int i = ; i <= n; ++i)
  58. {
  59. Scan(p);
  60. printf("%d\n", Work(p));
  61. }
  62. }

BZOJ 3384 上帝与集合的正确用法的更多相关文章

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

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

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

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

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

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

  4. bzoj P3884 上帝与集合的正确用法

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

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

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

  6. bzoj 3884 上帝与集合的正确用法(递归,欧拉函数)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3884 [题意] 求2^2^2… mod p [思路] 设p=2^k * q+(1/0) ...

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

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

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

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

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

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

随机推荐

  1. 笔试算法题(46):简介 - 二叉堆 & 二项树 & 二项堆 & 斐波那契堆

    二叉堆(Binary Heap) 二叉堆是完全二叉树(或者近似完全二叉树):其满足堆的特性:父节点的值>=(<=)任何一个子节点的键值,并且每个左子树或者右子树都是一 个二叉堆(最小堆或者 ...

  2. windows下简单使用pip

    1. 在python官网上下载python时会自带pip,并且在安装Python时若未取消会默认一并安装 2. 找出pip.exe所在位置, 3. 右击此电脑,点击属性 4. 高级系统设置 5. 点击 ...

  3. 二十一、MySQL NULL 值处理

    MySQL NULL 值处理 我们已经知道 MySQL 使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作. ...

  4. 数据追踪系统Zipkin 及其 Zipkin的php客户端驱动hoopak

    Zipkin是Twitter的一个开源项目,是一个致力于收集Twitter所有服务的监控数据的分布式跟踪系统,它提供了收集数据,和查询数据两大接口服务.Zipkin 是一款开源的分布式实时数据追踪系统 ...

  5. linux下mysql的权限设计总结

    1,进入mysql,终端中输入 mysql -u 用户名 -p   .enter键后,提示输入密码. 2,执行grant all privileges on xxxdb.* to usertest@& ...

  6. jmeter XML格式的结果中各属性的含义

    最近在搞jmeter,生成xml的测试报告,对报告字段进行解释,可能是自己不会找,网上资源不多,好不容易找到的,记录下来: 感谢博主:http://blog.163.com/zhang_jing/bl ...

  7. 3 View视图 URLconf

    1.视图 视图接受Web请求并且返回Web响应 视图就是一个python函数,被定义在views.py中 响应可以是一张网页的HTML内容,一个重定向,一个404错误等等 响应处理过程如下图: 2 准 ...

  8. vrpie下实现vrp模型和javascript的交互

    最近在做一个vrpie的项目,用vrp建模生成vrpie,然后在网页上面显示,这里需要和网页上面的其他内容交互,现在总结一下开发经验. 第一个需求是在网页上面点击那个的时候做一些事情,通过查找sdk找 ...

  9. Python框架之Django学习笔记(十二)

    Django站点管理 十一转眼结束,说好的充电没能顺利开展,反而悠闲的看了电视剧以及去影院看了新上映的<心花路放>.<亲爱的>以及<黄金时代>,说好的劳逸结合现在回 ...

  10. 【N-Quens II】cpp

    题目: Follow up for N-Queens problem. Now, instead outputting board configurations, return the total n ...