最大公约数Greatest Common Divisor(GCD)
一 暴力枚举法
原理:试图寻找一个合适的整数i,看看这个整数能否被两个整形参数numberA和numberB同时整除。这个整数i从2开始循环累加,一直累加到numberA和numberB中较小参数的一半为止。循环结束后,上一次寻找到的能够被两整数整除的最大i值,就是两数的最大公约数。
int getGreatestCommonDivisor(int numberA, int numberB)
{
||numberB < )
{
;
}
|| numberB <= )
{
;
}
int max = numberA > numberB ? numberA : numberB;
int min = numberA > numberB ? numberB : numberA;
)
{
return min;
}
;
;
; i <= min/; i++)
{
) && (numberB % i == ))
{
ret = i;
}
}
return ret;
}
二 辗转相除法(欧几里得算法)
原理:两个正整数a和b(a > b),它们的最大公约数等于a除于b的余数c和b之间的最大公约数。比如10和25,25除以10余数5,那么10和25的最大公约数,等于10和5的最大公约数。然后以此类推,直到两个数可以整除,或者其中一个数减小到1为止。
缺陷:当两个整形数较大时,a % b取模运算的性能比较低。
int gcd(int a, int b)
{
)
{
return b;
}
else
{
return gcd(b, a%b);
}
}
int getGreatestCommonDivisor(int numberA, int numberB)
{
||numberB < )
{
;
}
|| numberB <= )
{
;
}
int max = numberA > numberB ? numberA : numberB;
int min = numberA > numberB ? numberB : numberA;
)
{
return min;
}
else
{
return gcd(max, min);
}
}
三 更相减损术
原理:两个正整数a和b(a > b),它们的最大公约数等于a - b的差值c和较小数b的最大公约数。
缺陷:更相减损术的运算次数肯定远大于辗转相除法。特别是当两数相差比较大,相减的次数很大。
int gcd(int a, int b)
{
if (a == b)
{
return a;
}
if (a > b)
{
return gcd(a-b, b);
}
else
{
return gcd(b-a, a);
}
}
int getGreatestCommonDivisor(int numberA, int numberB)
{
||numberB < )
{
;
}
|| numberB <= )
{
;
}
int max = numberA > numberB ? numberA : numberB;
int min = numberA > numberB ? numberB : numberA;
)
{
return min;
}
else
{
return gcd(max, min);
}
}
四 辗转相除法和更相减损术相结合
原理:当a和b均为偶数,gcb(a, b) = 2 * gcb(a/2, b/2) = 2 * gcb(a>>1, b>>1) = gcb(a>>1, b>>1) << 1
当a为偶数,b为奇数,gcb(a, b) = gcb(a/2, b) = gcb(a>>1, b)
当a为奇数,b为偶数,gcb(a, b) = gcb(a, b/2) = gcb(a, b>>1)
当a和b均为奇数,先用更相减损术运算一次,gcb(a, b) = gcb(b, a-b),此时a-b是偶数,用上面的公式
说明:移位运算的性能非常快,a/2 转换成a>>1,a * 2 = a << 1
和1做&操作,判断奇偶:结果为真奇数,结果为假偶数
int gcd(int a, int b)
{
if (a == b)
{
return a;
}
)) && (!(b&))) // a和b均为偶数
{
, b>>) << ;
}
)) && (b&)) // a偶数,b奇数
{
, b);
}
) && (!(b&))) // a奇数,b偶数
{
);
}
else // a和b均为奇数
{
if (a > b)
{
return gcd(a-b, b);
}
else
{
return gcd(b-a, a);
}
return gcd(a-b, b);
}
}
int getGreatestCommonDivisor(int numberA, int numberB)
{
||numberB < )
{
;
}
|| numberB <= )
{
;
}
int max = numberA > numberB ? numberA : numberB;
int min = numberA > numberB ? numberB : numberA;
)
{
return min;
}
else
{
return gcd(max, min);
}
}
最大公约数Greatest Common Divisor(GCD)的更多相关文章
- Greatest common divisor(gcd)
欧几里得算法求最大公约数 If A = 0 then GCD(A,B)=B, since the GCD(0,B)=B, and we can stop. If B = 0 then GCD(A,B) ...
- LeetCode.1071-字符串最大公约数(Greatest Common Divisor of Strings)
这是小川的第391次更新,第421篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第253题(顺位题号是1071).对于字符串S和T,当且仅当S = T + ... + T ...
- upc组队赛17 Greatest Common Divisor【gcd+最小质因数】
Greatest Common Divisor 题目链接 题目描述 There is an array of length n, containing only positive numbers. N ...
- 845. Greatest Common Divisor
描述 Given two numbers, number a and number b. Find the greatest common divisor of the given two numbe ...
- [UCSD白板题] Greatest Common Divisor
Problem Introduction The greatest common divisor \(GCD(a, b)\) of two non-negative integers \(a\) an ...
- 2018CCPC桂林站G Greatest Common Divisor
题目描述 There is an array of length n, containing only positive numbers.Now you can add all numbers by ...
- CCPC2018 桂林 G "Greatest Common Divisor"(数学)
UPC备战省赛组队训练赛第十七场 with zyd,mxl G: Greatest Common Divisor 题目描述 There is an array of length n, contain ...
- 最大公约数和最小公倍数(Greatest Common Divisor and Least Common Multiple)
定义: 最大公约数(英语:greatest common divisor,gcd).是数学词汇,指能够整除多个整数的最大正整数.而多个整数不能都为零.例如8和12的最大公因数为4. 最小公倍数是数论中 ...
- hdu 5207 Greatest Greatest Common Divisor 数学
Greatest Greatest Common Divisor Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/ ...
随机推荐
- 在CentOS上安装Python
首先我们需要在服务器上安装一个比较新的 Python,CentOS 5.8 默认装的 Python 是 2.4.3. [root@nowamagic ~]# python -V Python 我们需要 ...
- PHP闭包研究
闭包也就是PHP的匿名函数, 但是和函数不同的是,闭包可以通过use使用函数声明时所在作用域的变量的值. 形式如下 $a = function($arg1, $arg2) use ($variable ...
- python_day7【模块configparser、XML、requests、shutil、系统命令-面向对象】之篇
python内置模块补充 一.configparser configparser:用户处理特定格式的文件,其本质是利用open打开文件 # 节点 [section1] #键值对k1 = v1 k2:v ...
- Oracle数据库——表的创建与管理
一.涉及内容 1.掌握使用OEM工具创建.修改和删除表. 2.掌握使用SQL语句创建.修改和删除表. 3.掌握使用SQL语句插入.修改和删除数据. 4.理解各种约束的作用,并能够使用OEM工具和SQL ...
- CentOS6.4系统启动失败故障排查
转:http://www.centoscn.com/CentosBug/osbug/2014/1028/4011.html 操作系统启动失败如下图报错: 故障现象: 从图中可以看到,操作系统启动的过程 ...
- Android 常遇错误解决方案
遇到问题描述: 运行android程序控制台输出 [2012-07-18 16:18:26 - ] The connection to adb is down, and a severe error ...
- CSS3之Flexbox布局
CSS3为我们提供了一种可伸缩的灵活的web页面布局方式-flexbox布局,它具有很强大的功能,可以很轻松实现很多复杂布局,在它出现之前,我们经常使用的布局方式是浮动或者固定宽度+百分比来进行布局, ...
- IOS:被误解的MVC和被神化的MVVM
MVC的历史 MVC,全称是 Model View Controller,是模型 (model)-视图 (view)-控制器 (controller) 的缩写.它表示的是一种常见的客户端软件开发框架. ...
- HTTP请求方法对照表
根据HTTP标准,HTTP请求可以使用多种请求方法. HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法. HTTP1.1新增了五种请求方法:OPTIONS, PUT, DELE ...
- mysql.server 文件修改起动多实例
如果你用mysql.server来启动的话,就要注意一下点,要修改一下里面的内容,修改如下:大约218行左右 查看复制打印? then print_defaults="$bindir/mys ...