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

相关文章

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Python lambda函数(匿名函数)、参数类型与递归全解析

《Pythonlambda函数(匿名函数)、参数类型与递归全解析》本文详解Python中lambda匿名函数、灵活参数类型和递归函数三大进阶特性,分别介绍其定义、应用场景及注意事项,助力编写简洁高效... 目录一、lambda 匿名函数:简洁的单行函数1. lambda 的定义与基本用法2. lambda

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

mysql递归查询语法WITH RECURSIVE的使用

《mysql递归查询语法WITHRECURSIVE的使用》本文主要介绍了mysql递归查询语法WITHRECURSIVE的使用,WITHRECURSIVE用于执行递归查询,特别适合处理层级结构或递归... 目录基本语法结构:关键部分解析:递归查询的工作流程:示例:员工与经理的层级关系解释:示例:树形结构的数

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

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的交集,并集方法一