题目描述

\[2^{2^{2\cdots}} ~mod ~p
\]

简单题,指数循环节。

由于当\(b>=\psi(p)\)时,有

\[a^b=a^{b ~mod~\psi(p)+\psi(p)} \pmod p
\]

显然这道题满足这个条件。

那当然是算\(\psi(p)\)然后\(2^{2^{2\cdots}}\)就可以变成

\[2^{2^{2^{2\cdots}}}=2^{(2^{2^{2\cdots}} ~mod~\psi(p)+\psi(p))} \pmod p
\]

啦。

往指数里头进行递归,每次算一个\(\psi(p')\)即可(显然有解)。

边界\(p=1\)时,显然式子\(=0\)。

参考代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<string>
#include<cstdlib>
#include<queue>
#include<vector>
#define INF 0x3f3f3f3f
#define PI acos(-1.0)
#define N 101
#define MOD 2520
#define E 1e-12
#define ll long long
using namespace std;
inline ll read()
{
int f=1,x=0;char c=getchar();
while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}
while(c>='0'&&c<='9'){x=x*10+c-'0';;c=getchar();}
return x*f;
}
inline int phi(int n)
{
int ans=n;
for(int i=2;i<=sqrt(n);++i){
if(n%i==0){
ans=ans/i*(i-1);
while(n%i==0) n/=i;
}
}
if(n>1) ans=ans/n*(n-1);
return ans;
}
int p;
inline ll qp(ll a,ll b,ll p)
{
ll ans=1;
for(;b;b>>=1){if(b&1)ans=(ans*a)%p;a=(a*a)%p;}
return ans%p;
}
inline int dfs(ll x)
{
if(x==1) return 0;
return qp(2,dfs(phi(x))+phi(x),x);
}
int main()
{
int t;
t=read();
while(t--){
p=read();
printf("%lld\n",dfs(p)%p);
}
return 0;
}

最新文章

  1. fir.im Weekly - 关于 iOS10 适配、开发、推送的一切
  2. [原创]zepto打造一款移动端划屏插件
  3. GJM : 进程、线程和协程的理解
  4. 【iCore3 双核心板_ uC/OS-III】例程十:消息队列
  5. 教务管理系统数据库E/R图
  6. Week8 软件规格说明书
  7. asp.net mvc 的几种分页Pager
  8. ef code first 您没有所需权限
  9. Html 初识样式表&amp;选择器
  10. Windows环境下Android Studio安装和使用教程
  11. gitup问题的处理
  12. CQOI2019(十二省联考)游记
  13. Canvas Demo
  14. Selenium WebDriver的工作原理
  15. 常见问题1:默认div隐藏,点击按钮时出现,再点击时隐藏。
  16. django之model多表操作
  17. Sequel Pro for Mac(MySQL 数据库管理工具)破解版安装
  18. 关于linux中SSH爆破总结
  19. Mac下JDK、Maven、Tomcat、Git开发安装及环境变量配置
  20. HDUOJ------2398Savings Account

热门文章

  1. 工具分享:excel2json,将Excel表格转换为JSON
  2. DOM事件: DOM事件级别、DOM事件流、DOM事件模型、DOM事件捕获过程、自定义事件
  3. Android组件化aar躺坑记:ButterKnife 报 元素值必须为常量表达式错误
  4. Linux虚拟环境配置(安装python包,连接至jupyter notebook)
  5. LeetCode 5214. 最长定差子序列(Java)HashMap
  6. SSM整合学习 二
  7. stompjs, websocket和nginx的配置
  8. Unity - 绘制正五边形网格
  9. java之spring mvc之初始spring mvc
  10. (四) Docker 使用Let&#39;s Encrypt 部署 HTTPS