WOJ1315-高级机密

在很多情况下,我们需要对信息进行加密 。特别是随着Internet的飞速发展,加密计算数就显得尤为重要。 
很早以前,罗马人为了在战争中传递信息,频繁地使用替换算法进行信息加密,然而在计算机技术高速发展的今天,这种替换算法显得不堪一击。因此密码研究人员正在试图寻找一种易于编码、但不易于解码的编码规则。 
目前比较流行的编码规则称为RSA,是由麻省理工学院的三名教授发明的。这种编码规则是基于一种求密取模算法的:对于给出的三个正整数a,b,c,计算a的b次方除以c所得的余数。

输入格式

输入数据有多组,每行三个整数a,b,c (0 <= a, b, c <= 2^30) 以一行0 0 0结束.

输出格式

对于每组输入数据,输出一行包含a^b mod c的值

样例输入

2 6 11
0 0 0

样例输出

9


/*算法利用了分治的思想,时间复杂度可以达到O(logn)

可以把b按二进制展开为b=p(n)*2^n+p(n-1)*2^(n-1)+...+p(1)*2+p(0)其中p(i)(0<=i<=n)为0或1

这样a^b=a^(p(n)*2^n+p(n-1)*2^(n-1)+...+p(1)*2+p(0))

=a^(p(n)*2^n)*a^(p(n-1)*2^(n-1)*...*a^(p(1)*2)*a^p(0)

对于p(i)=0的情况,a^p(i)*2^(i-1)=a^0=1,不用处理,我们要考虑的仅仅是p(i)=1的情况,a^(2^i)=(a^(p(i)*2(i-1)))^2

利用这一点,我们可以递推地算出所有的a^(2^i)

当然由算法1的结论a*b%c=((a%c)*b)%c,我们加上取模运算a^(2^i)%c=((a^(2(i-1))%c)*a^(2(i-1)))%c

于是再把所有满足p(i)=1的a^(2^i)%c按照算法1乘起来再%c就是结果*/
#include<stdio.h>
long long result(long long a,long long b,long long c){
    long long tmp=1;
    while(b>=1){
        if(b%2==1)
            tmp=a*tmp%c;
        a=a*a%c;
        b=b/2;
	}
    return tmp;
}
int main(){
    long long a,b,c;
    while(scanf("%lld %lld %lld",&a,&b,&c)!=EOF){
        if(a==0&&b==0&&c==0)
        break;    
        printf("%lld\n",result(a,b,c));
	}
    return 0;
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值