辗转相除法求最大公约数,利用最大公约数求最小公倍数(C)

养成好习惯,点个赞 再走;有问题,欢迎私信、评论,我看到都会回复的

文章目录

  • 辗转相除法求最大公约数
  • 输入两个正整数,求最大公约数和最小公倍数

辗转相除法求最大公约数

辗转相除法, 又名欧几里德算法(Euclidean algorithm),是求最大公约数的一种方法。

用较大数除以较小数,再用出现的余数(第一余数)去除除数,再用出现的余数(第二余数)去除第一余数,如此反复,直到最后余数是0为止。如果是求两个数的最大公约数,那么最后的除数就是这两个数的最大公约数。

比如:

z (被除数) x(除数) z%x(余数)
125 50 25
50(上一行的除数) 25(上一行的余数) 0(余数为0时,除数即为这两个数的最大公约数)

循环:

#include//辗转相除法 
int main(){
	int z, x, t;//z,x为输入的两个数,t为交换器
	
	//请输入两个正整数
	scanf("%d%d", &z, &x);
	
	if(x > z){
		t = x;
		x = z;
		z = t;
	} 
	do{
		t = x;
		x = z % x;
		z = t;	
	}while(x != 0);
	printf("这两个整数的最大公约数为%d", z);
	return 0;
}

输入:56 12
输出:

这两个整数的最大公约数为4

输入两个正整数,求最大公约数和最小公倍数

记住这个公式:最小公倍数 * 最大公约数 = 两个数相乘

递归:(不推荐使用递归哦,递归相比循环虽然代码更加简洁,但实际上超级耗费计算机资源,能用循环解决的问题就别用递归)

#include
int main()
{
	int g(int x,int y);//函数声明
	int m, n, d, e;
	
	//输入正整数m、n
	scanf("%d%d", &m, &n);
	
	if(m < n){
		d = m; m = n; n = d;
	}	
	printf("最大公约数 = %d\n最小公倍数 = %d\n", g(m,n), m*n/g(m,n));
	return 0;
 } 
 
 int g(int x,int y)//求最大公约数
 {
 	return (x % y == 0) ? y : g(y, x % y);
 }

输入:20 15
输出:

最大公约数 = 5
最小公倍数 = 60

再写一个解法(使用的是循环:

#include
int main()
{
	int g(int x, int y);//函数声明
	int m, n, d, e;
	
	// 输入正整数m、n
	scanf("%d%d", &m, &n);
	
	if(m < n){
		d = m; m = n; n = d;
	}	
	printf("最大公约数 = %d\n最小公倍数 = %d\n", g(m,n), m*n/g(m,n));
	return 0;
 } 
 
 int g(int m, int n){ //求最大公约数
 	int t;
 	do{
		t = n;
		n = m%n;
		m = t;	
	}while(n != 0);
 	return m;
 }

C语言入门题目文章导航:

  1. 素数(C)
  2. 水仙花数(C)
  3. 斐波那契数列(C)
  4. 完数(C)
  5. 阶乘(C)
  6. 直角杨辉三角形(C)
  7. 大写字母、小写字母、ASCII码(C)
  8. 输入一个字符,找出他的前驱字符和后继字符(C)
  9. 最大数、最小数(C)
  10. 百钱买百鸡(C语言,枚举法)
  11. 本篇文章
  12. 输入一个年份和一个月份,输出该年此月天数;知道日期,计算该日是本年的第几天(C)
  13. 输入一个不多于4位的正整数,求它的位数,并按逆序输出各位数字(C)
  14. 利用二维数组求方阵的主次对角线之和(C)
  15. 在一个二维数组中找出最小数及其所在的行和列(C)
  16. 找出一个二维数组中的鞍点(C)
  17. 删除指定字符串的指定字符(C)
  18. 字符串(C)
  19. 条件判断语句1(C)
  20. 条件判断语句2(C)
  21. 圆、三角形、正方形、长方体、计算1到100的和、和差积商、平均值
  22. 输入三个整数,要求程序把数据按从小到大的顺序放入x y z中,然后输出(C)
  23. 18个数围成一圈,求相邻三数之和最大数(C)
  24. 梯形法求定积分(C)
  25. 学生与课程的综合问题(C)

你可能感兴趣的:(那些编程入门题(C))