C语言例4-28:求两个正整数的最大公约数。

算法分析:

  1. 输入两个正整数m和n
  2. m%n 的余数 r,然后 m=n;n=r;
  3. 当 n=0, 则m是最大公约数,算法结束;否则转至执行2,重复上述过程,直到n=0为止

代码如下:

复制代码
//求两个正整数的最大公约数。
#include<stdio.h>
int main(void)
{
	int m,n,r;
	printf("输入两个正整数: \n");
	scanf("%d,%d",&m,&n);
	
	while(n)
	{
		r=m%n;
		m=n;
		n=r;
	}
	printf("这两个正整数的最大公约数是: %d\n",m);
	
	return 0;
}

结果如下:

**辗转相除法:**是求两个自然数的最大公约数的一种方法,也叫欧几里德算法。

例如,求(319,377):

∵ 319÷377=0(余319)

∴(319,377)=(377,319);

∵ 377÷319=1(余58)

∴(377,319)=(319,58);

∵ 319÷58=5(余29)

∴ (319,58)=(58,29);

∵ 58÷29=2(余0)

∴ (58,29)= 29;

∴ (319,377)=29。

可以写成右边的格式。

用辗转相除法求几个数的最大公约数,可以先求出其中任意两个数的最大公约数,再求这个最大公约数与第三个数的最大公约数,依次求下去,直到最后一个数为止。最后所得的那个最大公约数,就是所有这些数的最大公约数。

相关推荐
chilavert3181 分钟前
技术演进中的开发沉思-151 java-servlet:会话管理
java·开发语言
霸道流氓气质11 分钟前
Java中使用Collator实现对象List按照中文姓名属性进行A-Z的排序实现
java·开发语言·list
ttghgfhhjxkl15 分钟前
《macOS 配置 GO 语言后,如何切换不同 GO 版本?》
开发语言·macos·golang
长存祈月心35 分钟前
安装与切换Rust版本
开发语言·后端·rust
剑指~巅峰37 分钟前
Rust智能指针的奇妙之旅:从踩坑到顿悟
开发语言·人工智能·深度学习·机器学习·rust
m0_7482313138 分钟前
从企业开发到AI时代:Java的新征程与技术蜕变
java·开发语言·人工智能
流星白龙44 分钟前
双端迭代器:从 `next_back()` 到零拷贝“滑动窗口”——Rust DoubleEndedIterator 全景指南
开发语言·后端·rust
Aurorar0rua1 小时前
C Primer Plus Notes 10
c语言·开发语言·算法
安当加密1 小时前
基于ASP身份认证网关实现Web系统免代码改造的单点登录方案
java·开发语言·前端
island13141 小时前
Rust 零成本抽象原理:性能与安全性的编译期融合
开发语言·rust