首页 > 其他 > 详细

poj1995---Raising Modulo Numbers

时间:2018-08-15 11:55:24      阅读:192      评论:0      收藏:0      [点我收藏+]

tips:

  1.(a*b)%c=[(a%c)*(b%c)]%c,其他的公式都是由此引出的

  2.代码里主要是这样处理了(a*b)%c=(a%c)*b%c

  3.快速幂也叫二分幂,有递归写法,判断b的奇偶,详见算法笔记

技术分享图片
//long long 如果输入不使用%lld的话,如果输入数据超过int范围会wa
//(a+b)%c=(a%c+b%c)%c;
//(a*b)%c=[(a%c)*(b%c)]%c
//(a^b)%c=(a%c)^b%c---幂是多次乘法
//(a*b)%c=(a%c)*b%c
//有详细证明:https://blog.csdn.net/qq_36285879/article/details/53284431
#include<cstdio>
using namespace std;
int z;
int m,h;
long long ans,a,b;
long long binaryPow(long long a,long long b, int m ){
    long long ans=1;
    while(b>0){
        if(b&1){
            ans=ans*a%m;//(a*b)%c=(a%c)*b%c
        }
        a=a*a%m;//(a%c)
        b=b>>1;
    }
    return ans;
}
int main(){
    scanf("%d",&z);
    while(z--){
        scanf("%d%d",&m,&h);
        long long ans=0;
        for(int i=0;i<h;i++){
            scanf("%lld%lld",&a,&b);
            ans+=binaryPow(a,b,m);
        }
        ans=ans%m;
        printf("%lld\n",ans);


    }
    return 0;
}
View Code

 

poj1995---Raising Modulo Numbers

原文:https://www.cnblogs.com/SUMaywlx/p/9480470.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!