最大公约数的算法

== 欧几里德算法 ==

1.若a=0,则d:=b、跳至第9步;
2.若b=0,则d:=a、跳至第9步;
3.若a<b,则交换a和b;
4.d:=a mod b;
5.a:=b;
6.b:=d;
7.若d<0,则跳至第4步;
8.d:=b;
9.结束。


== Stein算法 ==

1.若a=0,则d:=b、跳至第12步;
2.若b=0,则d:=a、跳至第12步;
3.令正整数p:=0;
4.若a和b都是偶数,则a:=a/2、b:=b/2、p:=p+1;
5.若a和b仍都是偶数,则跳至第4步;
6.若a是偶数、b是奇数,则a:=a/2;
7.若a仍是偶数,则跳至第6步;
8.若a是奇数、b是偶数,则b:=b/2;
9.若b仍是偶数,则跳至第8部;
10.若a和b都不是偶数,则a:=b、b:=|a-b|;
11.若b<>0,则跳至第4步;
12.d:=a*exp(2,p);
13.结束。


通常,在面对一般情况时,可以采用欧几里德算法,该算法由于其历史悠久,更具可读性且易交流;同时,其效率在很多时候是优于Stein算法的。而当面对大数运算时,Stein算法无疑是最佳的选择。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值