【板子】快速幂

//lg 1226
//快速幂
#include<bits/stdc++.h>
using namespace std;

long long a,n,p;

long long nn;

long long qpow()
{
    long long b=a;
    long long ans=1;
    while(n)
    {
        if(n&1) ans=ans*b%p;
        n/=2;
        b=b*b%p;
    }
    return ans;
}

int main()
{
    // freopen("working.in","r",stdin);
    // freopen("working.out","w",stdout);
    cin>>a>>n>>p;
    nn=n;
    printf("%lld^%lld mod %lld=%lld",a,nn,p,qpow());
    return 0;
}
posted @   yeyou26  阅读(10)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示