码迷,mamicode.com
首页 > 其他好文 > 详细

(模板)快速幂

时间:2019-10-16 20:02:15      阅读:65      评论:0      收藏:0      [点我收藏+]

标签:ash   dash   ace   pac   end   std   include   ++   模板   

—————————————————————————————————————————————————— —————————————————————前排护眼——————————————————————— ——————————————————————————————————————————————————

#include<bits/stdc++.h>
using namespace std;

long b,p,k,ans=1;
long x,y,z;

int main(){
    cin>>b>>p>>k;
    x=b;y=p;z=k;
    
    while(y>1){
        if(y%2==0){
            x*=x;
            y/=2;
            x%=z;
        }
        else{
            ans*=x;
            ans%=z;
            x*=x;
            y/=2;
            x%=z;
        }
    }
    ans*=x;
    ans%=z;
    cout<<ans<<endl;
}

(模板)快速幂

标签:ash   dash   ace   pac   end   std   include   ++   模板   

原文地址:https://www.cnblogs.com/xiaozezz/p/11687605.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!