c语言-给定两个数,求这两个数的最大公约数

cpp 复制代码
#include <stdio.h>
int test(int a, int b)
{
	while (b != 0)
	{
		int temp = a % b;
		a = b;
		b = temp;
	}

	return a;
}

int main()
{
	int a = 0, b = 0;
	scanf_s("%d%d", &a, &b);
	int c=test(a,b);
	printf("%d", c);
	return 0;
}

最大公约数(Greatest Common Divisor,简称 GCD) ,也叫最大公因数,指的是:对于两个或多个整数,能同时整除它们的最大正整数

举个例子:

  • 求 12 和 18 的最大公约数:

    1. 先列出 12 的所有约数(能整除 12 的数):1、2、3、4、6、12
    2. 再列出 18 的所有约数:1、2、3、6、9、18
    3. 找出两者共有的约数(公约数):1、2、3、6
    4. 其中最大的那个就是最大公约数:6

编程中求最大公约数的常用方法(欧几里得算法 / 辗转相除法):

两个数的最大公约数 = 较小数 和 两数相除余数 的最大公约数,直到余数为 0,此时的除数就是最大公约数。

代码执行过程(以 12 和 18 为例):

  1. 初始:a=12,b=18 → 计算 temp=12%18=12 → a=18,b=12
  2. 第二次循环:temp=18%12=6 → a=12,b=6
  3. 第三次循环:temp=12%6=0 → a=6,b=0 → 循环结束,返回 a=6
相关推荐
power 雀儿1 小时前
掩码(Mask)机制 结合 多头自注意力函数
算法
会叫的恐龙1 小时前
C++ 核心知识点汇总(第六日)(字符串)
c++·算法·字符串
小糯米6011 小时前
C++顺序表和vector
开发语言·c++·算法
We་ct1 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
Lionel6892 小时前
分步实现 Flutter 鸿蒙轮播图核心功能(搜索框 + 指示灯)
算法·图搜索算法
小妖6662 小时前
js 实现快速排序算法
数据结构·算法·排序算法
xsyaaaan2 小时前
代码随想录Day30动态规划:背包问题二维_背包问题一维_416分割等和子集
算法·动态规划
zheyutao3 小时前
字符串哈希
算法
A尘埃3 小时前
保险公司车险理赔欺诈检测(随机森林)
算法·随机森林·机器学习
大江东去浪淘尽千古风流人物4 小时前
【VLN】VLN(Vision-and-Language Navigation视觉语言导航)算法本质,范式难点及解决方向(1)
人工智能·python·算法