辗转相除,又名欧几里德算法(Euclidean algorithm),是求两个正整数之最大公因子的算法。它是已知最古老的算法, 其可追溯至前300年。它首次出现于欧几里德的《几何原本》中,而在中国则可以追溯至东汉出现的《九章算术》。 以前学碾转相除的时候也没怎么考虑,看到书上说要先比较两个数的大小再碾转相除我就习惯性地先比较大小了,可是今天发现碾转相除法是不用比较两个数的大小的。。。
设我们有两个数m、n
1、用m除以n,得余数r
2、使m=n ,n=r
3、若r=0,则m就是最大公约数;
若r不等于0,返回第1步 我们可以看到,如果m>n,那么没说的;如果m<n,在第一次m除以n后,余数恰好为m,这样一交换,最后还会变成m>n的情况。
C语言实现代码为:
1 #include <stdio.h> 2 3 int main() 4 5 { 6 7 int m, n, r = 1; 8 9 scanf("%d%d", &m, &n); 10 11 while (r != 0) 12 13 { 14 15 r = m % n; 16 17 m = n; 18 19 n = r; 20 21 } 22 23 printf("%d", m); 24 25 return 0; 26 27 }
还有一个利用条件运算符写的求最大公约数程序代码
1 #include<stdio.h> 2 3 int main() 4 5 { 6 7 int m, n; scanf("%d%d", &m, &n); 8 9 while(m > n ? (m = m % n) : (n = n % m)); 10 11 printf("%d", m + n); return 0; 12 13 }