递归法求最大公约数和最小公倍数的实现代码
发布时间:2023-10-07 02:11:34
数学原理:
设有两个数num1和num2,假设num1比较大。令余数r = num1 % num2。
当r == 0时,即num1可以被num2整除,显然num2就是这两个数的最大公约数。
当r != 0时,令num1 = num2(除数变被除数),num2 = r(余数变除数),再做 r = num1 % num2。递归,直到r == 0。
以上数学原理可以用具体的两个数做一下分析,这样容易理解。
代码实现(求最大公约数):
#include <iostream>
using namespace std;
int gcd(int a, int b);//声明最大公约数函数
int main()
{
int num1 = 1;
int num2 = 1;
cin >> num1 >> num2;
while(num1 == 0 || num2 == 0)//判断是否有0值输入,若有则重新输入
{
cout << "input error !" << endl;
cin >> num1 >> num2;
}
cout << "The gcd of " << num1 << " and " << num2 << " is: " << gcd(num1, num2) << endl;//调用最大公约数函数
return 0;
}
int gcd(int a, int b)//函数定义
{
int max = a > b ? a : b;
int min = a < b ? a : b;
a = max;
b = min;
int r = a % b;
if(0 == r)//若a能被b整除,则b就是最大公约数。
return b;
else
return gcd(b, r);//递归
}
最小公倍数的求法建立在求最大公约数的方法之上。因为最小公倍数等于两个数的积除以最大公约数。
代码实现(求最小公倍数):
#include <iostream>
using namespace std;
int gcd(int a, int b);//声明最大公约数函数
int main()
{
int num1 = 1;
int num2 = 1;
int lcm = 1;
cin >> num1 >> num2;
while(num1 == 0 || num2 == 0)//判断是否有0值输入,若有则重新输入
{
cout << "input error !" << endl;
cin >> num1 >> num2;
}
lcm = num1 / gcd(num1, num2) * num2;//先除后乘可以在一定程度上防止大数
cout << "The lcm of " << num1 << " and " << num2 << " is: " << lcm << endl;
return 0;
}
int gcd(int a, int b)//函数定义
{
int max = a > b ? a : b;
int min = a < b ? a : b;
a = max;
b = min;
int r = a % b;
if(0 == r)//若a能被b整除,则b就是最大公约数。
return b;
else
return gcd(b, r);//递归
}
以上是仅仅限与求两个书的最大公约数和最小公倍数,当数字有很多时,该法是否依然适用,还有待考证。


猜你喜欢
- MD5加密简介哈希算法又称散列算法,是将任何数据转换成固定长度的算法的统称。 从本质上讲,MD5也是一种哈希算法,其输出是生成12
- 这个列表总结了10个Java开发人员最常犯的错误。Array转ArrayList当需要把Array转成ArrayList的时候,开发人员经常
- 这篇文章主要介绍了Java并发编程预防死锁过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可
- 绑定多个按钮到同一个事件1.添加代码private void clauseElementClicked(object sender, Eve
- 差不多一年前在自己的项目中用过这效果,虽然很简单,但还是写写。1、首先在你的res目录下新建anim子目录,并在anim目录下新建两个文件:
- 前言集合是Java开发日常开发中经常会使用到的。关于集合类,《阿里巴巴Java开发手册》中其实还有另外一个规定:本文就来分析一下为什么会有如
- 本文实例为大家分享了Android原生视频播放VideoView的具体代码,供大家参考,具体内容如下布局文件activity_video.x
- spring boot配置hikari连接池属性事件起因与一个简单应用经常发生Young GC,甚至在没有请求量的情况下也经常发生GC (A
- 在 C# 中,结构体是值类型数据结构。它使得一个单一变量可以存储各种数据类型的相关数据。struct 关键字用于创建结构体。结构体是用来代表
- Spring Cloud Zuul 集成Swagger1.准备服务注册中心eureka-server2.创建微服务swagger-servi
- 为什么Android要申请权限简单说下在Android6.0及6.0以上一些google认为涉及“危险和用户隐私”的一些权限不仅要做清单文件
- 目录一、连接查询:1、多对一:2、一对多:3、多对多:二、嵌套查询:1、多对一:2、一对多:首先在mysql中确立表:#表一:地址国家表CR
- 1、Handle,MessageQueue,Message类图Handle: 处理消息,并提供一系列函数帮忙我们创建消息和插入消息到消息队列
- 1:在很多APP里点击返回键,都可以看到返回键由亮变为暗2:实现方法也是很简单的(1)新建一个页面<RelativeLayout &n
- 背景随着公司业务越来越复杂,在同一个列表中需要展示各种类型的数据。总体结构ItemViewAdapter: 每种类型的卡片分别都是不同的It
- 当开发基于软件模式的游戏时,通过缩放视频缓冲区来适应显示尺寸是最棘手的问题之一。当面对众多不同的分辨率时(比如开放环境下的Android),
- 二叉树的分类(按存储结构)树的分类(按存储结构) &nbs
- Android设备之间可以除了通过wifi热点共享上网,还可以通过蓝牙共享上网,后面这个功能很少人使用,但适合某台设备没有wifi却有蓝牙的
- 在应用登陆页面我们需要填写用户名和密码。当填写这些信息的时候,软键盘会遮挡登陆按钮,这使得用户体验较差,所以今天就来解决这个问题1:登陆布局
- 本文实例讲述了android编程实现添加文本内容到sqlite表中的方法。分享给大家供大家参考,具体如下:第一步: 创建表CREATE TA