• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 递归法求最大公约数和最小公倍数的实现代码

递归法求最大公约数和最小公倍数的实现代码

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了最大公约数最小公倍数,最小公倍数最小公约数,最小公约数和公倍数,公约数和公倍数,什么是公约数和公倍数等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com


       数学原理:

       设有两个数num1和num2,假设num1比较大。令余数r = num1 % num2。
       当r == 0时,即num1可以被num2整除,显然num2就是这两个数的最大公约数。
       当r != 0时,令num1 = num2(除数变被除数),num2 = r(余数变除数),再做 r = num1 % num2。递归,直到r == 0。
       以上数学原理可以用具体的两个数做一下分析,这样容易理解。

代码实现(求最大公约数):

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);//递归   
}
</div>
最小公倍数的求法建立在求最大公约数的方法之上。因为最小公倍数等于两个数的积除以最大公约数。

代码实现(求最小公倍数):

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);//递归   
}
</div>
以上是仅仅限与求两个书的最大公约数和最小公倍数,当数字有很多时,该法是否依然适用,还有待考证。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 递归法求最大公约数和最小公倍数的实现代码

相关文章

  • 2017-05-28深入探讨:宏、内联函数与普通函数的区别
  • 2017-05-28去掉vs2010中ipch文件和.sdf文件的解决方法
  • 2017-05-28详解C语言中的符号常量、变量与算术表达式
  • 2017-05-28C语言 makefile学习及实现实例
  • 2017-05-28C语言对堆排序一个算法思路和实现代码
  • 2017-05-28VC++实现CStdioFile写入及读取文件并自动换行的方法
  • 2017-05-28c语言多线程编程使用示例
  • 2017-05-28C连接Mysql数据库代码
  • 2017-05-28基于Windows C++ 应用程序通用日志组件的使用详解
  • 2017-05-28浅谈C++基类的析构函数为虚函数

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C++中关于[]静态数组和new分配的动态数组的区别分析
    • C++基础学生管理系统
    • 详解C语言中的rename()函数和remove()函数的使用方法
    • c++ 快速排序算法【过程图解】
    • 深入理解C++中变量的存储类别和属性
    • 6个变态的C语言Hello World程序
    • QString和char以及string之间的赋值详解
    • 在C语言中转换时间的基本方法介绍
    • 归并排序的递归实现与非递归实现代码
    • C语言 以数据块的形式读写文件详解及实现代码

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有