1600: Big Mod (大数幂取模)

ResultTIME LimitMEMORY LimitRun TimesAC TimesJUDGE
3s8192K1756336Standard

Calculate

 

 

for large values of B, P, and M using an efficient algorithm. (That's right, this problem has a time dependency !!!.)

Input

Three integer values (in the order B, P, M) will be read one number per line. B and P are integers in the range 0 to 2147483647 inclusive. M is an integer in the range 1 to 46340 inclusive.

Output

The result of the computation. A single integer.

Sample Input

 

3
18132
17

17
1765
3

2374859
3029382
36123

Sample Output

 

13
2
13195
/*
*/
  1. #include <stdio.h>
  2. #include <memory>
  3. int main ( )
  4. {
  5. int a,b,n;
  6. while ( scanf ( "%d%d%d",&a,&b,&n )!= EOF )
  7. {
  8.   bool b2 [ 35 ];
  9.   memset (b2, 0, sizeof (b2 ) );
  10.   int tmp=b,i,d= 1;
  11.   for ( i= 0; tmp> 0 ; i++ )
  12.   {
  13.    b2 [i ]=tmp% 2;
  14.    tmp=tmp/ 2;
  15.   }
  16.   for (;i>= 0;i-- )
  17.    {
  18.    d=d*d%n;
  19.    int aa=a%n;
  20.    if ( b2 [i ]== 1 )
  21.     d=d*aa%n;
  22.    }
  23.    printf ( "%d/n",d );
  24. }
  25. return 0;
  26. }

方法二:超短代码

#include <cstdio>
int b, p, m, k;
int main()
{
 while(scanf("%d%d%d", &b, &p, &m)!=EOF)
    {
  for(k=1,b=b%m; p ; p/=2,b=b*b%m)
   if(p%2) k=k*b%m;
  printf("%d\n", k%m);
 }
 return 0;
}

 

方法三:递归 时间稍慢

#include <cstdio>
int m;
int bigmod(int a,int b)
{
    if(!b)return 1;
    int d=bigmod(a,b>>1)%m;
    return  b&1?(d*d%m*a)%m:(d*d)%m;
}
int main ()
{
    int a,b;
    while (scanf("%d%d%d",&a,&b,&m)!=EOF)
    {
        int ans=bigmod(a%m,b)%m;
        printf("%d\n",ans);
    }
    return 0;
}

快速幂取模 最短代码 for(k=1,a=a%m; b ; b>>=1,a=a*a%m) if(b&1) k=k*a%m; 求a^b(mod m) k%m是答案。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值