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;
}


猜你喜欢

转载自blog.csdn.net/lxq1071717521/article/details/77913939
今日推荐