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。

可以写成右边的格式。

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

相关推荐
电信2301杨臣6 分钟前
QT---信号与槽
开发语言·qt
明月看潮生12 分钟前
青少年编程与数学 02-019 Rust 编程基础 07课题、字符串
开发语言·青少年编程·rust·编程与数学
抽风的雨61013 分钟前
【python基础知识】Day26 函数
开发语言·python
编程有点难1 小时前
Python训练打卡Day22
开发语言·python·机器学习
咕噜咕噜啦啦2 小时前
Python爬虫入门
开发语言·爬虫·python
dubochao_xinxi2 小时前
✅ TensorRT Python 安装精简流程(适用于 Ubuntu 20.04+)
开发语言·python·ubuntu
感谢地心引力2 小时前
【Matlab】最新版2025a发布,深色模式、Copilot编程助手上线!
开发语言·windows·matlab·copilot
Java程序员-小白2 小时前
使用java -jar命令指定VM参数-D运行jar包报错问题
java·开发语言·jar
范纹杉想快点毕业2 小时前
以项目的方式学QT开发(一)——超详细讲解(120000多字详细讲解,涵盖qt大量知识)逐步更新!
c语言·数据结构·c++·git·qt·链表·github
xueyinan3 小时前
小刚说C语言刷题—1088求两个数M和N的最大公约数
c语言