LCM GCD
来源:互联网 发布:电子科技大学 大数据 编辑:程序博客网 时间:2024/04/30 22:21
gcd(a, b),就是求a和b的最大公约数
lcm(a, b),就是求a和b的最小公倍数
然后有个公式
a*b = gcd * lcm ( gcd就是gcd(a, b), ( •̀∀•́ ) 简写你懂吗)
解释(不想看就跳过){
首先,求一个gcd,然后。。。
a / gcd 和 b / gcd 这两个数互质了,也就是 gcd( a / gcd ,b / gcd ) = 1,然后。。。
lcm = gcd * (a / gcd) * (b / gcd)
lcm = (a * b) / gcd
所以。。a*b = gcd * lcm
}
所以要求lcm,先求gcd
辣么,问题来了,gcd怎么求
辗转相除法
while循环
1 LL gcd(LL a, LL b){2 LL t;3 while(b){4 t = b;5 b = a % b;6 a = t;7 }8 return a;9 }
还有一个递归写法
1 LL gcd(LL a, LL b){2 if(b == 0) return a;3 else return gcd(b, a%b);4 }5 6 LL gcd(LL a, LL b){7 return b ? gcd(b, a%b) : a;8 }9 //两种都可以
辣么,lcm = a * b / gcd
(注意,这样写法有可能会错,因为a * b可能因为太大 超出int 或者 超出 longlong)
所以推荐写成 : lcm = a / gcd * b
然后几个公式自己证明一下
gcd(ka, kb) = k * gcd(a, b)
lcm(ka, kb) = k * lcm(a, b)
gcd(a,b)=gcd(a,a+b)
上次做题碰到这个公式
lcm(S/a, S/b) = S/gcd(a, b)
S = 9,a = 4,b = 6,小数不会lcm,只好保留分数形式去通分约分。
当我看到右边那个公式。。。。
(╯°Д°)╯┻━┻
这TM我怎么想的到,给我证明倒是会证。 T_T
0 0
- gcd,lcm
- gcd & lcm
- LCM GCD
- GCD LCM
- lcm/gcd
- gcd & lcm
- GCD LCM
- 【GCD&LCM】
- gcd && lcm
- gcd,lcm 汇编版本
- gcd,lcm 汇编版本
- zoj 1577 GCD & LCM
- ZOJ 1577 GCD & LCM
- gcd 与 lcm
- ZOJ 1577 GCD & LCM
- UVa 11388 - GCD LCM
- ZOJ 1577 - GCD & LCM
- GCD LCM--UVA11388
- linux常用命令总结
- JVM运行机制
- jquery基本知识点
- platform平台总线
- BZOJ 小约翰的游戏John 反尼姆博弈
- LCM GCD
- 有无C标签在JSP页面的取值(两种方式)
- 我的2016
- 详解java中抽象类和接口的区别
- 2017.1.17【初中部 GDKOI】模拟赛B组
- 【Centos7】 firewalld命令行
- stl算法设计理念_一元函数对象和一元谓词
- apt软件包管理
- Activity注册InputChannel和处理Event(六)