当前位置: 首页 > news >正文

gcd得最大公约数,辗转相除法理解

欧几里得算法_百度百科 (baidu.com) 

——————

百度百科证法一的一些便于理解的细节:

我们求 a 和 b 的最大公约数。

(如果a是b的倍数,那么b就是最大公约数。)

a>b,a可以表示为 a = kb + r

设d为a和b的最大公约数

对上式等号左右两端同时除以d,得 a/d = kb/d + r/d

a/d 和 kb/d都是整数,那么r/d也是整数。那么r也是d的倍数。同时r<b,r与b的最大公约数也是d

( r<d是因为r = a%b  (由a的表示可知))

那么问题就转化成求 b 与 r 的最大公约数。

即 gcd(a,b) = gcd(b,a mod b)

r会一直变小,为0时,b就是最大公约数了        (b最小为1,当b为1时,余数必然为0)

——————

(当然再进一次循环就是 a 与 0 。返回a即可):

long long gcd(long long a,long long b)
{if (a<b)swap(a,b); if (b==0)      return a;elsereturn gcd(a%b,b);
}

相关文章:

  • Dockerfile镜像实战
  • ReactHooks:渲染与useState
  • openssl3.2 - 在VS2019下源码调试openssl.exe
  • 如何通过Burp Suite专业版构建CSRF PoC
  • 【纯CSS特效源码】(二)精美的立体字
  • JavaScript基础05
  • css 怎么绘制一个带圆角的渐变色的边框
  • UGUI Image图像控件替换图片
  • Java 8 中的 Stream 轻松遍历树形结构
  • 视频转为序列图的软件,让视频批量转为序列图
  • Object.keys()
  • Go语言学习记录——用正则表达式(regexp包)来校验参数
  • mysql进阶-索引基础
  • 高效构建Java应用:Maven入门和进阶(五)
  • 【JavaScript】es6开发常用技巧
  • 03Go 类型总结
  • classpath对获取配置文件的影响
  • css布局,左右固定中间自适应实现
  • Idea+maven+scala构建包并在spark on yarn 运行
  • JavaScript函数式编程(一)
  • Laravel Mix运行时关于es2015报错解决方案
  • PHP 的 SAPI 是个什么东西
  • Python学习之路16-使用API
  • ReactNativeweexDeviceOne对比
  • session共享问题解决方案
  • sublime配置文件
  • Vue2 SSR 的优化之旅
  • Vue小说阅读器(仿追书神器)
  • Web设计流程优化:网页效果图设计新思路
  • 道格拉斯-普克 抽稀算法 附javascript实现
  • 短视频宝贝=慢?阿里巴巴工程师这样秒开短视频
  • 关于extract.autodesk.io的一些说明
  • 诡异!React stopPropagation失灵
  • 前端面试题总结
  • 前端之React实战:创建跨平台的项目架构
  • 区块链将重新定义世界
  • 首页查询功能的一次实现过程
  • 腾讯视频格式如何转换成mp4 将下载的qlv文件转换成mp4的方法
  • 腾讯优测优分享 | 你是否体验过Android手机插入耳机后仍外放的尴尬?
  • 新手搭建网站的主要流程
  • 一些css基础学习笔记
  • 3月7日云栖精选夜读 | RSA 2019安全大会:企业资产管理成行业新风向标,云上安全占绝对优势 ...
  • 400多位云计算专家和开发者,加入了同一个组织 ...
  • Redis4.x新特性 -- 萌萌的MEMORY DOCTOR
  • 大数据全解:定义、价值及挑战
  • 带你开发类似Pokemon Go的AR游戏
  • ​DB-Engines 11月数据库排名:PostgreSQL坐稳同期涨幅榜冠军宝座
  • ​渐进式Web应用PWA的未来
  • ###C语言程序设计-----C语言学习(3)#
  • #NOIP 2014# day.1 T2 联合权值
  • #pragam once 和 #ifndef 预编译头
  • #pragma pack(1)
  • (层次遍历)104. 二叉树的最大深度
  • (二)【Jmeter】专栏实战项目靶场drupal部署
  • (附源码)ssm高校升本考试管理系统 毕业设计 201631