求最大公因数,使用欧几里得算法以及更相减损术法(未完)

本文介绍了两种求解最大公因数的方法:欧几里得算法与更相减损术。通过逐步分解的方式详细展示了如何利用这两种算法找出两个长整型数的最大公因数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 使用欧几里得算法求最大公因数:

long gcd( long m, long n )
{
  while( n != 0)
  {
        long rem = m % n;
        m = n;
        n = rem;
   }  
}

设R=m%n;Q=m/n

那么:

m=R1*n+R1;
R2=n%R1;Q2=n/R1; => n=Q2*R1+R2;

m=Q1*(Q2*R1+R2)+R1=(Q1*Q2+1)*R1+Q1*R2;
R3=R1%R2; Q3=R1/R2; => R1=Q3*R2+R3;

m=(Q1*Q2+1)*(Q3*R2+R3)+Q1*R2=(Q1*Q2+1)*Q3*R2+(Q1*Q2+1)*R3+Q1*R2=(Q1*Q2*Q3+Q3+Q1)*R2+(Q1*Q2+1)*R3;
R4=R2%R3; Q4=R2/R3; => R2=Q4*R3+R4;

m=(Q1*Q2*Q3+Q3+Q1)*(Q4*R3+R4)+(Q1*Q2+1)*R3=(Q1*Q2*Q3*Q4+Q3*Q4+Q1*Q4+Q1*Q2+1)*R3+(Q1*Q2*Q3+Q3+Q1)*R4;
R5=R3%R4; Q5=R3/R4

......

不断分解,直到Rn=0时,m=C1*Rn-1+C2*Rn=C1*Rn-1,那么Rn-1就是m的最大公因数。

2. 使用更相减损术法求最大公因数:

 

转载于:https://www.cnblogs.com/xiayy860612/archive/2012/10/09/2716338.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值