更相减损法和辗转相除法(GCD)求最小公倍数和最大公约数

更相减损法和辗转相除法(GCD)求最小公倍数和最大公约数

标签(空格分隔): 算法 算法竞赛


这两种算法平时经常听到,听起来也很装逼,但是我老是忘了他们的原理,今天好好想想,写下来。

  1. 更相减损法
    更相减损法最早起源于我国的《九章算术》,用于求两个数的最小公倍数。大意是给定两个数a,b,如果存在偶数,就将偶数以2;否则,就比较两数大小,用大数减小数,得到一个差;对差和剩下的那个小数重复该过程,直到两数相等,下一次相减结果为0,这时的数就是a和b的最大公约数。注意,去掉偶数除以2的步骤,也正确,但是加上这一步可能会让时间复杂度减少。
    例如:15和12。15-12=3;12-3=9;9-3=6;6-3=3;3=3,跳出。则最大公因数是3。
    算法的C/C++代码写法如下(循环实现):
int gcdgxjs(int a,int b)    {while (a!=b)    {if (aif (a>b)    a-=b;else        b-=a;}return a;
)
  1. 辗转相除法
    辗转相除法最早是由欧几里得发现的,也被用来求最大公约数。算法是这样的:给定两个数a,b,求a%b,如果余数非0,就继续用除数除以余数,重复该过程,直到除数为0。此时的被除数,就是最大公约数。
    例如,42和12。42%12=6;12%6=0,6&0,此时的6即为最大公约数。
    算法的C/C++代码写法如下(递归实现):
int gcd(int a,int b)    {if (b==0)return a;gcd(b,a%b);
}

上面就是这两个算法的具体实现过程。除此之外,再补充一个定理:两个正整数a,b。假设他们的最大公约数是p,最小公倍数是q,则q=a*b/p(即ab=pq)。证明很简单,多想想就好了,在此不再赘述。

转载于:https://www.cnblogs.com/yichuan-sun/p/9624172.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/398436.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一幅长文细学JavaScript(五)——ES6-ES11新特性

5 ES版本 摘要 ES5的先天不足致使ES后续版本的发展,这也是前端人员绕不开的一个点。如果我们想要在工作和面试中轻松解决问题,那么了解ES6-ES11是必不可少的。 在本文中,我将采用一种更加通俗的方式来讲述这一块知识点,而不是照搬…

Python自动化运维工具fabric的安装

使用shell命令进行复杂的运维时,代码往往变得复杂难懂,而使用python脚本语言来编写运维程序,就相当于开发普通的应用一样,所以维护和扩展都比较简单,更重要的是python运维工具fabric能自动登录其他服务器进行各种操作&…

项目开发一些注意事项

项目开发一些注意事项 1、一些简单的方法可以让你的代码看起来更明了,如函数或者方法,尽量的写的小一些,如果太冗长,尝试抽出一块写成一个函数;2、如果业务逻辑比较复杂,判断选项较多,可以把判断…

一幅长文细学Vue(一)——Webpack打包工具

1 项目开发工具 摘要 ​ 在本文中,我们会详细讨论webpack是如何打包发布项目,不过对于Vue来说,Vite可以做到和webpack一样的功能。 声明:如果想要看懂此文章,需具备node.js中npm的知识。 作者:来自ArimaMis…

I00005 打印直角三角形字符图案

曾经的计算机,没有显示屏,人们操作计算机时,用打印机记录执行的操作命令。 后来有了显示屏,不过最初的显示屏是字符频幕,输出只能是字符。 即使是今日,计算机已经进入多窗口图形界面时代,有时程…

由于不能随便改路径,所以写在这里

export LD_LIBRARY_PATH/usr/local/cuda-8.0/lib64:$LD_LIBRARY_PATHexport PATH/usr/local/cuda-8.0/bin:$PATH export LD_LIBRARY_PATH/root/anaconda2/envs/LTproto261/lib export PYTHONPATH/dev/LT/SegNet/caffe-segnet/python:$PYTHONPATH转载于:https://www.cnblogs.com…

动态数组使用

1 #include<stdio.h>2 #include<stdlib.h>3 4 int main()5 {6 int i;7 int n; //用于记录输入的整数的个数 8 int *p; //用于指向动态数组的存储空间 9 int sum0,average; //用于记录输入的整数的和与平均值 10 11 scanf("%d"…

一幅长文细学Vue(二)——Vue基础入门

2 Vue基础入门 摘要 ​ 在本文中&#xff0c;我们会快速地入门Vue。主要了解的是Vue各种指令语法。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附上部分演示代码。 作者&#xff1a;来自ArimaMisaki创作 文章目录2 Vue基础入门2.1 概述2.1.1 Vue…

Linux下安装Redis及搭建主从

Linux下安装Redis 首先在官网下载对应版本的redis包&#xff0c;这里本人使用的是redis-4.0.8.tar.gz。然后在服务器中存放redis包的路径下执行tar –vxf redis-4.0.8.tar.gz&#xff08;这里对应下载的包&#xff09;&#xff0c;解压redis后,cd 进入 redis-4.0.8&#xff08;…

图解安装CentOS 6.6

以下是在虚拟机上安装CentOS 6.6的过程。一、安装文件:CentOS-6.6-x86_64-bin-DVD.iso二、安装步骤# 虚拟机的配置这里省略&#xff0c;在百度上有很多帖子可以参考。开启虚拟机进入安装界面&#xff0c;如下图所示选择第一个选项&#xff0c;按Enter安装程序加载完后&#xff…

phonegap安卓手机开发入门

先安装安卓开发安环境 http://www.cnblogs.com/zhangsanshi/p/3582368.html 安装phonegap 在安装ant http://www.cnblogs.com/yuzhongwusan/archive/2013/03/26/2982411.html 资源下载地址 http://pan.baidu.com/s/1mgHTNDm#path%252F 转载于:https://www.cnblogs.com/sung/p/4…

一幅长文细学Vue(三)——组件基础(上)

3 组件基础&#xff08;上&#xff09; 摘要 ​ 在本文中&#xff0c;我们将学习什么是SPA&#xff0c;以及Vue中组件的基本使用。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附上部分演示代码&#xff0c;main.js文件的代码通常不贴出&#xff…

综合练习:词频统计

下载一首英文的歌词或文章 将所有,.&#xff1f;&#xff01;’:等分隔符全部替换为空格 将所有大写转换为小写 生成单词列表 fopen(news.txt,r) newsf.read() f.close() sep,.!"?: for c in sep:newsnews.replace(c, )wordListnews.lower().split()for w in wordList:pr…

一幅长文细学Vue(四)——组件基础(下)

4 组件基础&#xff08;下&#xff09; 摘要 ​ 在本文中年我们会了解什么是props&#xff0c;怎么利用props在父组件和子组件之间传递数据&#xff1b;什么是计算属性&#xff0c;还有什么是事件。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附…

linux中fcntl()、lockf、flock的区别

fcntl()、lockf、flock的区别 ——lvyilong316 这三个函数的作用都是给文件加锁&#xff0c;那它们有什么区别呢&#xff1f;首先flock和fcntl是系统调用&#xff0c;而lockf是库函数。lockf实际上是fcntl的封装&#xff0c;所以lockf和fcntl的底层实现是一样的&#xff0c;对文…

获取.properties后缀的数据

在MyPro.properties中的数据如下&#xff1a; NameABC 测试类中&#xff1a; Properties properties new Properties(); String configFile "MyPro.properties"; //将MyPro.properties文件编译成文件流 InputStream is ConfigManager.class.getClassLoader().getR…

iOS开发拓展篇—音频处理(音乐播放器6)

一、图片处理 说明&#xff1a; Aspect表示按照原来的宽高比进行缩放。 Aspectfit表示按照原来的宽高比缩放&#xff0c;要求看到全部图片&#xff0c;后果是不能完全覆盖窗口&#xff0c;会留有空白。 Aspectfill表示按照原来的宽高比缩放&#xff0c;但只能看到部分图片。引发…

词频统计预处理之综合练习

下载一首英文的歌词或文章 news , 生成词频统计 sep,.;:"" for c in sep:newsnews.replace(c, )wordlistnews.lower().split()wordDict{} for w in wordlist:wordDict[w]wordDict.get(w,0)1wordSetset(wordlist) for w in wordSet:wordDict[w]wordlist.count(w)f…

一幅长文细学Vue(五)——组件高级(上)

5 组件高级&#xff08;上&#xff09; 摘要 ​ 在本文中&#xff0c;我们会详细讨论watch侦听器的基本使用&#xff0c;并且了解vue中常用的生命周期函数、实现组件之间的数据共享&#xff0c;最后学习如何在vue3.x项目中全局配置axios。 声明&#xff1a;为了文章的清爽性&am…

IOS开发之----常用加密方法

本文转载至 http://blog.csdn.net/wildfireli/article/details/23191983 &#xff08;AES、MD5、Base64&#xff09; 分类&#xff1a; iPhone 2014-04-08 16:30 187人阅读 评论(0) 收藏 举报 目录(?)[] 1、AES加密 NSDataAES.h文件 // // NSData-AES.h // Smile // // Create…