c语言求最大公约数和最小公倍数
2015-07-20 10:33
369 查看
求最大公约数和最小公倍数
假设有两个数a和b,求a,b的最大公约数和最小公倍数实际上是一个问题,得出这两个数的最大公约数就可以算出它们的最小公倍数。
最小公倍数的公式是 a*b/m
m为最大公约数
因为 a=m*i; b=m*j;
最小公倍数为 m*i*j
计算a和b的最大公约数的方法:
方法一:
更相损减法:
反复把两数的最大者减去最小者,直至两数相等,这个数就是最大公约数
如 4 和 6
6-4=2
2个数变成了4和2
4-2=2
两个数变成了2和2
2=2 即2是两数的最大公约数
方法二:
辗转相除法:
大致原理类似于 更相损减法
a>b
a%b的余数为r
假设有两个数a和b,求a,b的最大公约数和最小公倍数实际上是一个问题,得出这两个数的最大公约数就可以算出它们的最小公倍数。
最小公倍数的公式是 a*b/m
m为最大公约数
因为 a=m*i; b=m*j;
最小公倍数为 m*i*j
计算a和b的最大公约数的方法:
方法一:
更相损减法:
反复把两数的最大者减去最小者,直至两数相等,这个数就是最大公约数
如 4 和 6
6-4=2
2个数变成了4和2
4-2=2
两个数变成了2和2
2=2 即2是两数的最大公约数
方法二:
辗转相除法:
大致原理类似于 更相损减法
a>b
a%b的余数为r
相关文章推荐
- 【C++】修改VS2013的默认堆栈大小
- 彻底搞清 C/C++中a++与++a的区别
- 步步为营(三)贪心(2)选择不相交区间
- C++ HOJ 约瑟夫问题 之 神牛代码
- C++ 简单读写文本文件、统计文件的行数、读取文件数据到数组
- [libxml2]_[C/C++]_[使用libxml2读取分析xml文件]
- [libxml2]_[C/C++]_[使用libxml2读取分析xml文件]
- C语言按关键字搜索文件夹中文件的方法
- C语言函数指针与回调函数
- C++中通过指针修改类内私有成员变量 & 类的大小
- C/C++校招笔试面试经典题目总结五
- 线程安全的SRILM语言模型c++接口
- 错排公式及其推导
- 据序和中序序列或者也许为了一个二进制序列,恢复二进制和打印图像(c语言)
- C++ STL学习之stack
- C++中static类成员
- C++ HOJ 约瑟夫问题 的 数组、链表及STL实现
- c++新增的4个类型转换运算符
- iOS C语言8_指针
- 不可或缺 Windows Native (24) - C++: 运算符重载, 自定义类型转换