java 算法 求最大公约数

本贴最后更新于 2792 天前,其中的信息可能已经沧海桑田

本人菜鸟一枚,突然之间,偶得上帝灵光闪现,突然感觉自己日子过的太轻松,然后,自杀式的买了一本算法书,从今天开始了地狱般的生活;
算法第一章讲的是,欧几里得算法求其目的就是找到两个数的最大公约数,然后,我马上关上书,喝了一杯茶,脑海中回想着,这都是啥??对于一个数学从来都没有及格的我来说,想放弃
吐槽完毕,说正题,何为最大公约数,直接百度,谷歌,360,通过一系列的查询,来个官方版的

f2c17fb4c473499fb366a29260637521-WX201709142137142x.png

这。。。。是啥?没看懂
其实,最大公约数,即为能够同时被两个整数除的最大的数,还不懂?上图
02e760411ab14b318ffed2f3ce3200c1-WX201709142141172x.png

如果还不懂,请关闭本页面,然后,打开百度,找个视频看一下吧!我无能为力了。
欧几里得算法:又称辗转相除法,用于计算两个正整数,a,b 的最大公约数,计算原理依赖于下面的定理
定理:gcd(a,b) = gcd(b,a mod b)(a>b 且 a mod b 不为 0)
有人会问,mod 是啥?这个是求余啊! _MOD_是求余运算符,例如 a mod b=c,表明 a 除以 b 余数为 c
证明:a 可以表示成 a = kb +r 则 r=a mod b
假设 d 是 a,b 的一个公约数,则有 d|a ,d|b 而,r=a-kb 因此 d|r
因此 d 也是(b,a mod b)的公约数
因此(a,b)和(b,a mod b)的公约数是一样的,最大的公约数也必然相等

看懂没?我也没咋看懂

分析一下吧,
假设 x>y x 和 y 的最大公约数用 f(x,y)表示
假设 x/y = a
x%y = b
所以 ay+b = x
因为 a 为 x 除以的整数部分,b 为 x 除以 y 的余数部分,所以 a
y+b = x
将上面的调换一下 b= x-a*y
因为 x 和 y 都能被 f(x,y)整数 所以 f(x,y)是 x 和 y 的最大公约数
所以 b 也同样能被 f(x,y)整除 即 x 和 y 的最大公约数 f(x,y)它是 b 的约数,所以求 x 和 y 的最大公约数也就相当于求 y 和 b 的最大公约数(因为,这里 x>y 而且 x%y 肯定小于 y,所以,这样一来,我们的范围缩小了)
所以 欧几里得公式也就这么来了
f(x,y) = f(y,x%y)
所以,这个算法就是不停的迭代,直到找出 x%y=0 的时候,停止迭代,那个时候,最大的公约数就是 y 了

下面为,书中的一个求最大公约数的案例

/** * 算法分析: * 计算两个非负数p和q的最大公约数,若q是0,则最大的公约数是p,否则,p除q,得到余数r,p和q最 * 大公约数即为q和r的最大公约数 * Created by huxd on 2017/9/14. */ //欧几里得算法 public static int gcd(int p ,int q){ if(q == 0) return p; int r = p%q; return gcd(q,r); }

实际代码

package Test1; import java.util.*; public class Tset1 { public static void (String[] args) { Scanner scan = new Scanner(System.in);// 接收控制台输入的信息 System.out.print("请输入第一个整数:"); int x = scan.nextInt(); // 取出控制台输入的信息 System.out.print("请输入第二个整数:"); int y = scan.nextInt(); // 取出控制台输入的信息 System.out.println(gcd(x, y));// 调用maxCommonDivisor()方法 } public static int gcd(int x, int y) { // 防止输入为0 if (x == 0 || y == 0) { return 0; } //添加一个保证 x>y if (x < y) { int temp = x; temp = y; y = x; } //算法实现 if (x % y == 0) { return y; } else { return gcd(y, x % y); } } }
  • 算法
    437 引用 • 254 回帖 • 24 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 747 回帖 • 1 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    6 引用 • 26 回帖 • 545 关注
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    56 引用 • 85 回帖
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖 • 1 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    180 引用 • 408 回帖 • 484 关注
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 114 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    298 引用 • 763 回帖
  • 代码片段

    代码片段分为 CSS 与 JS 两种代码,添加在 [设置 - 外观 - 代码片段] 中,这些代码会在思源笔记加载时自动执行,用于改善笔记的样式或功能。

    用户在该标签下分享代码片段时需在帖子标题前添加 [css] [js] 用于区分代码片段类型。

    162 引用 • 1096 回帖
  • sts
    2 引用 • 2 回帖 • 228 关注
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 635 关注
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 8 关注
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 497 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1280 回帖 • 5 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 726 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖 • 1 关注
  • Office

    Office 现已更名为 Microsoft 365. Microsoft 365 将高级 Office 应用(如 Word、Excel 和 PowerPoint)与 1 TB 的 OneDrive 云存储空间、高级安全性等结合在一起,可帮助你在任何设备上完成操作。

    5 引用 • 34 回帖
  • danl
    164 关注
  • WebSocket

    WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

    48 引用 • 206 回帖 • 291 关注
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 556 关注
  • V2Ray
    1 引用 • 15 回帖
  • Windows

    Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

    227 引用 • 476 回帖
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 29 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 507 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖 • 1 关注