您的位置:首页 > 大数据 > 人工智能

POJ-1995-Raising Modulo Numbers

2014-04-03 13:17 351 查看
水题一个吧~其实就是一个快速幂~

代码:

#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
const int maxn=50000;
int m,h;
long long ans;
long long QMulti(long long a,long long n)
{
long long ans=1;
while(n)
{
if(n&1)
ans=(ans*a)%m;
a=(a*a)%m;
n>>=1;
}
return ans;
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
ans=0;
scanf("%d%d",&m,&h);
for(int i=0;i<h;i++)
{
long long a,b;
scanf("%I64d%I64d",&a,&b);
ans=(ans+QMulti(a,b))%m;
}
printf("%I64d\n",ans);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: