博客
关于我
C++求两个数的最大公约数
阅读量:609 次
发布时间:2019-03-12

本文共 1684 字,大约阅读时间需要 5 分钟。

最大公约数(GCD)的计算问题,是一个在编程和数学中经常遇到的基础问题。针对这一问题,我想到的两个方法各具特色,既可以通过灵活的思路解决问题,也能利用更高效的算法实现。让我们从这些角度来深入探讨。

思路一:余数遍历法

这是一种直观的方法,适合刚刚接触编程的开发者。具体思路是这样的:首先,将a和b中较小的那个数赋值给c。例如,不妨设a大于b,那么我们会令c = b。接下来,我们对a和b分别用c作为模,执行求余运算。然后,从c开始逐步 decrement(减1),依次即将c, c-1, c-2,…,直到a和b对c的求余结果都等于0。如果其中一方的余数已经变为0,而另一方仍有非零余数,这个c就是我们要找的最大公约数。需要注意的是,如果在遍历过程中出现了c变为0的情况,则可以直接返回0,表示两个数互质。

代码实现

对于这种方法,我们可以编写如下代码:

#include 
using namespace std;int gcd(int a, int b) { int c = (a > b) ? b : a; while (a % c != 0 || b % c != 0) { c--; if (c <= 0) { return 0; } } return c;}int main() { int a, b, max_div; cout << "please input two integer:"; cin >> a >> b; max_div = gcd(a, b); cout << "the greatest common divisor of "; cout << a << " and " << b << " is " << max_div; return 0;}

思路二:辗转相除法

相比于余数遍历法,这种方法更为高效,优 publication推荐使用。其基本思路是:假设a大于b,将a除以b。如果a不能被b整除,就将b的值赋给a,而余数赋给b。重复这个过程直到a能够被b整除,此时b的值就是最大公约数。

这种算法的几何意义在于,当将问题不断缩小到更小的数对时,每次操作都会将问题转化为更简单的形式。这种逐步逼近的策略,不仅逻辑清晰,而且计算效率也很高。对于编程实现而言,这个算法尤其适合再利用递归的优势,能够编写简洁而高效的代码。当然,如果使用非递归的方法也能达到类似的效果,但递归的实现方式可能会更贴近问题的数学本质。

代码实现

可以通过以下代码来实现上述思路:

#include 
using namespace std;int gcd2(int a, int b) { if (a < b) { return b; } if (a % b != 0) { return gcd2(a, b); } return b;}int main() { int a, b, max_div; cout << "please input two integer:"; cin >> a >> b; max_div = gcd2(a, b); cout << "the greatest common divisor of "; cout << a << " and " << b << " is " << max_div; return 0;}

总结

这两种方法各有其独特的适用场景。如果需要通过暴力破解方式,就可以使用余数遍历法来筛选可能的最大公约数;如果需要一种更优雅、更高效的算法,那么辗转相除法便是最佳选择。在实际编程中,尤其是在处理较小的数时,这两种方法都会表现出良好的性能。如果想要进一步提升效率,可以考虑将其中一种方法与快速幂结合,利用数学优化技巧,实现更高效的求解过程。

转载地址:http://hgmxz.baihongyu.com/

你可能感兴趣的文章
npm和yarn的使用对比
查看>>
npm如何清空缓存并重新打包?
查看>>
npm学习(十一)之package-lock.json
查看>>
npm安装 出现 npm ERR! code ETIMEDOUT npm ERR! syscall connect npm ERR! errno ETIMEDOUT npm ERR! 解决方法
查看>>
npm安装crypto-js 如何安装crypto-js, python爬虫安装加解密插件 找不到模块crypto-js python报错解决丢失crypto-js模块
查看>>
npm安装教程
查看>>
npm报错Cannot find module ‘webpack‘ Require stack
查看>>
npm报错Failed at the node-sass@4.14.1 postinstall script
查看>>
npm报错fatal: Could not read from remote repository
查看>>
npm报错File to import not found or unreadable: @/assets/styles/global.scss.
查看>>
npm报错TypeError: this.getOptions is not a function
查看>>
npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
查看>>
npm淘宝镜像过期npm ERR! request to https://registry.npm.taobao.org/vuex failed, reason: certificate has ex
查看>>
npm版本过高问题
查看>>
npm的“--force“和“--legacy-peer-deps“参数
查看>>
npm的安装和更新---npm工作笔记002
查看>>
npm的常用操作---npm工作笔记003
查看>>
npm的常用配置项---npm工作笔记004
查看>>
npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
查看>>
npm编译报错You may need an additional loader to handle the result of these loaders
查看>>