6-5 递归法求两个数的最大公约数

2024-05-11 14:36

本文主要是介绍6-5 递归法求两个数的最大公约数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

分数 5

作者 王跃萍

单位 东北石油大学

递归法求两个数的最大公约数。

函数接口定义:

int  gys(int m,int n);

其中 mn 都是用户传入的参数。函数用递归法求mn的最大公约数。

裁判测试程序样例:

#include <stdio.h>
int  gys(int m,int n);
int main()
{
int m,n;
scanf("%d%d",&m,&n);
printf("%d\n",gys(m,n));
return 0;
}/* 请在这里填写答案 */

输入样例:

24 16

输出样例:

8

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

求最大公约数(Greatest Common Divisor, GCD)有几种常用的方法,包括欧几里得算法(Euclidean Algorithm)和更相减损术(辗转相除法)。这里,我将介绍欧几里得算法,因为它是最常用且易于理解的算法。

欧几里得算法(Euclidean Algorithm)

欧几里得算法的基本思想是:对于两个整数a和b(a > b),它们的最大公约数与b和a mod b的最大公约数相同。这个性质可以一直递归地应用,直到其中一个数为0,此时另一个数就是它们的最大公约数。

以下是欧几里得算法的伪代码:

function gcd(a, b)  while b ≠ 0  t = b  b = a mod b  a = t  return a

更相减损术(辗转相除法)

更相减损术是另一种求最大公约数的方法,它基于的原理是:两个整数的最大公约数等于其中较小的数和两数的差的最大公约数。具体步骤是:

  1. 如果a和b相等,则它们的最大公约数就是a或b。
  2. 否则,如果a大于b,则a减b,并更新a的值为a-b;如果b大于a,则b减a,并更新b的值为b-a。
  3. 重复步骤2,直到a和b相等,此时得到的值就是最大公约数。

欧几里得算法C程序如下:

// 计算两个整数的最大公约数  
int gys(int m, int n) {  // 如果 n 为 0,则 m 就是最大公约数  if (n == 0) {  return m;  }  // 递归调用 gys 函数,传入 n 和 m 除以 n 的余数  return gys(n, m % n);  
}

这篇关于6-5 递归法求两个数的最大公约数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/979813

相关文章

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

Jackson库进行JSON 序列化时遇到了无限递归(Infinite Recursion)的问题及解决方案

《Jackson库进行JSON序列化时遇到了无限递归(InfiniteRecursion)的问题及解决方案》使用Jackson库进行JSON序列化时遇到了无限递归(InfiniteRecursi... 目录解决方案‌1. 使用 @jsonIgnore 忽略一个方向的引用2. 使用 @JsonManagedR

java两个List的交集,并集方式

《java两个List的交集,并集方式》文章主要介绍了Java中两个List的交集和并集的处理方法,推荐使用Apache的CollectionUtils工具类,因为它简单且不会改变原有集合,同时,文章... 目录Java两个List的交集,并集方法一方法二方法三总结java两个List的交集,并集方法一

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

C#比较两个List集合内容是否相同的几种方法

《C#比较两个List集合内容是否相同的几种方法》本文详细介绍了在C#中比较两个List集合内容是否相同的方法,包括非自定义类和自定义类的元素比较,对于非自定义类,可以使用SequenceEqual、... 目录 一、非自定义类的元素比较1. 使用 SequenceEqual 方法(顺序和内容都相等)2.

锐捷和腾达哪个好? 两个品牌路由器对比分析

《锐捷和腾达哪个好?两个品牌路由器对比分析》在选择路由器时,Tenda和锐捷都是备受关注的品牌,各自有独特的产品特点和市场定位,选择哪个品牌的路由器更合适,实际上取决于你的具体需求和使用场景,我们从... 在选购路由器时,锐捷和腾达都是市场上备受关注的品牌,但它们的定位和特点却有所不同。锐捷更偏向企业级和专

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

PHP实现二叉树遍历(非递归方式,栈模拟实现)

二叉树定义是这样的:一棵非空的二叉树由根结点及左、右子树这三个基本部分组成,根据节点的访问位置不同有三种遍历方式: ① NLR:前序遍历(PreorderTraversal亦称(先序遍历)) ——访问结点的操作发生在遍历其左右子树之前。 ② LNR:中序遍历(InorderTraversal) ——访问结点的操作发生在遍历其左右子树之中(间)。 ③ LRN:后序遍历(PostorderT