光速幂板子

光速幂(矩阵光速幂类似)

时间复杂度O(T+sqrt(m))(T是询问次数,m是模数大小)

s = s q r t ( p )   p 是 模 数 大 小 a x ≡ a x s ∗ s + x % s m o d   p s=sqrt (p)\ p是模数大小\\ a^x\equiv a^{\frac{x}{s}*s+x\%s} mod \ p s=sqrt(p) paxasxs+x%smod p

// 代码没有验证过正确性,大致是这个样子
#include<bits/stdc++.h>
using namespace std;
const int mod = 1e9+7;
int sqrtm=sqrt(mod);
int f1[sqrtm+5],f2[sqrtm+5];
int main()
{
   
	f1[0]=f2[0]=1;
	for(int i=1;i<=sqrtm;i++)f1[i]=1ll*f1[i-1]*a%mod;
	for(int i=1;i<=sqrtm;i++)f2[i]=1ll*f2[i-1]*f1[sqrtm]%mod;
	//求a^q次
	int res=1ll*f2[q/sqrtm]*f1[q%sqrtm]%mod;
	
}
全部评论

相关推荐

04-30 15:51
已编辑
上海交通大学 机械工程师
点赞 评论 收藏
分享
暑期是进不了大厂了想问问前端友友们&nbsp;,后面应该如何沉淀自己,我想秋招再冲一下尤其是八股,应该抓哪一块是重点,理解到什么程度呢,要学到什么深度才能抗住拷打。还有场景题如何去准备。期待友友们的解答。
命烈焰带我飞走:找个中厂小厂先看看吧,去了熟悉熟悉项目,简历上扒点东西,之后刷刷sobb上百度美团快手的日常实习,流程都比较快轮次也少,别给自己太大压力,一步一步来,先不用想着暑期,转正,秋招那些事情,另外如果可能的话可以关注下面试时候的形象,穿搭,环境这些,其实实习主要就是看个眼缘,看着好看声音好听其实加分不少..八股这些不要死记硬背,挨个拿去问问chatgpt,这个东西做出来是为了解决什么问题,有啥效果,自己有想法有个模糊的概念就可以了,人家也知道你是学生,实习生没有什么kpi,放你去面都是希望能把你招进去的,场景题算法题没做过你可以边试着写边跟面试官说你的想法思路,也可以直说没见过让他们给你提示,反正最后都是与或非顺序分支循环存取值那套。总之建议是别为了秋招..出去旅旅游放松放松,少投几家少背八股多写写代码
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务