C语言复习---获取最大公约数(辗转相除法和更相减损法)
源自:百度百科
辗转相除法
辗转相除法:辗转相除法是求两个自然数的最大公约数的一种方法,也叫欧几里德算法。
例如,求(,):
∵ ÷=(余319)
∴(,)=(,);
∵ ÷=(余58)
∴(,)=(,);
∵ ÷=(余29)
∴ (,)=(,);
∵ ÷=(余0)
∴ (,)= ;
∴ (,)=。
用辗转相除法求几个数的最大公约数,可以先求出其中任意两个数的最大公约数,再求这个最大公约数与第三个数的最大公约数,依次求下去,直到最后一个数为止。最后所得的那个最大公约数,就是所有这些数的最大公约数。
更相减损法
第一步:任意给定两个正整数;判断它们是否都是偶数。若是,则用2约简;若不是则执行第二步。
第二步:以较大的数减较小的数,接着把所得的差与较小的数比较,并以大数减小数。继续这个操作,直到所得的减数和差相等为止。
则第一步中约掉的若干个2与第二步中等数的乘积就是所求的最大公约数。
其中所说的“等数”,就是最大公约数。求“等数”的办法是“更相减损”法。所以更相减损法也叫等值算法。
例1.用更相减损术求98与63的最大公约数。
解:由于63不是偶数,把98和63以大数减小数,并辗转相减:
-=
-=
-=
-=
-=
-=
所以,98和63的最大公约数等于7。
这个过程可以简单的写为:
(,)=(,)=(,)=(,)=(,)=(,)=(,)=.
例2.用更相减损术求260和104的最大公约数。
解:由于260和104均为偶数,首先用2约简得到130和52,再用2约简得到65和26。
此时65是奇数而26不是奇数,故把65和26辗转相减:
-=
-=
-=
所以,260与104的最大公约数等于13乘以第一步中约掉的两个2,即13**=。
这个过程可以简单地写为:
(,)(//) =>(,)=(,)=(,)=(,)=. (**) => []
比较:
代码实现
一:最简单方法
#include <stdio.h>
#include <stdlib.h> int main()
{
int m, n,temp,i;
scanf("%d", &m);
scanf("%d", &n); if (m>n)
{
temp = m;
m = n;
n = temp;
} for (i = m; i >= ;i--)
if (m%i== && n%i==)
break; printf("%d\n", i); system("pause");
return ;
}
二:辗转相除法(递归)
#include <stdio.h>
#include <stdlib.h> int gcd(int a, int b)
{
int mod;
if ((mod = a % b) == 0)
return b;
return gcd(b, mod);
} int main()
{
int m, n,ret;
scanf("%d", &m);
scanf("%d", &n); ret = gcd(m, n);
printf("%d", ret); system("pause");
return ;
}
三:辗转相除法(非递归)
int gcd(int a, int b)
{
int mod=a % b;
while (mod!=)
{
a = b;
b = mod;
mod = a % b;
}
return b;
}
四:更相减损法(非递归)
#include <stdio.h>
#include <stdlib.h>
#include <math.h> int gcd(int a, int b)
{
int val= a - b;
while (val != b)
{
if (b>val)
{
a = b;
b = val;
}
else
{
a = val;
}
val = a - b;
}
return val;
} int main()
{
int m, n,ret,temp,count=;
scanf("%d", &m);
scanf("%d", &n); if (m == n)
{
printf("%d", m);
return ;
} if (m < n)
{
temp = m;
m = n;
n = temp;
} while (m% == && n% == )
{
count++;
m /= ;
n /= ;
} ret = gcd(m, n);
printf("%d", ret*((int)pow(,count))); //使用pow需要进行(int)转换,不然会报错 system("pause");
return ;
}
C语言复习---获取最大公约数(辗转相除法和更相减损法)的更多相关文章
- C语言,最大公约数---更相减损术
// 最大公约数 更相减损法 int commonDivisor() { int i,k,n=0; printf("请输入两个不同的正整数,用,隔开\n"); scanf(&quo ...
- 求最大公因数(辗转相除法&更相减损术)
求最大公因数(辗转相除法&更相减损术) 辗转相除法 又名欧几里得算法 ,其原理其实是基于这个定理:\(gcd(a,b)=gcd(b,a\%b)\),详细证明,而任何数与0的最大公约数是它本身 ...
- C语言复习---获取最小公倍数(公式法:两个数相乘等于最小公倍数乘以最大公约数)
公式法:两个数相乘等于最小公倍数乘以最大公约数 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib ...
- C语言复习---获取矩阵的对角和
#include <stdio.h> #include <stdlib.h> #include <math.h> #define MAX 5 int main() ...
- 【C语言】两个指针(地址)相减
两个指针相减,为两个指针之间间隔这两个指针类型的数目. 如:int *p,*q; p-q=(p地址-q地址)/sizeof(int) #include <stdio.h> int main ...
- C语言复习---零散补充
一:double和float使用scanf获取数据 printf输出float和double都可以用%f,double还可以用%lf. 2 scanf输入float用%f,double输入用%lf,不 ...
- Swift3.0语言教程获取字符串编码与哈希地址
Swift3.0语言教程获取字符串编码与哈希地址 Swift3.0语言教程获取字符串编码与哈希地址,以下将讲解字符串中其它内容的获取方法. 1.获取字符串编码 在NSString中可以使用2个属性获取 ...
- Swift3.0语言教程获取C字符串
Swift3.0语言教程获取C字符串 Swift3.0语言教程获取C字符串,为了让Swift和C语言可以实现很好的交互,开发者可以使用NSString的cString(using:)方法在指定编码格式 ...
- Swift3.0语言教程获取字符
Swift3.0语言教程获取字符 Swift3.0语言教程获取字符,在字符串中获取某一下标位置(下标索引)处的字符是很常见的功能,在NSString中使用character(at:)方法实现,其语法形 ...
随机推荐
- C# LINQ to XML示例
static void Main(string[] args) { // Create the data source by using a collection initial ...
- 大话Java中的哈希(hash)结构(一)
o( ̄▽ ̄)d 小伙伴们在上网或者搞程序设计的时候,总是会听到关于“哈希(hash)”的一些东西.比如哈希算法.哈希表等等的名词,那么什么是hash呢? 一.相关概念 1.hash算法:一类特殊的算法 ...
- HTML表单与输入实例
解释HTML 表单用于搜集不同类型的用户输入.HTML 表单包含表单元素.表单元素指的是不同类型的 input 元素.复选框.单选按钮.提交按钮等等.<input> 元素<input ...
- kubernetes 网络故障遇见的坑
1.记录一下自己搭建kubernetes 集群遇见的坑. 过程是我学技术以来最大的bug,处处都是坑,稍微写成一点, 就完全起不来, 起不来之后, 还找不到故障点, 郁闷之极. 后续会慢慢分享给大家. ...
- ELK安装部署
一.ELK简介 ELK是Elasticsearch.Logstash.Kibana的简称,这三者是核心套件,但并非全部.Elasticsearch是实时全文搜索和分析引擎,提供搜集.分析.存储数据三大 ...
- 学习笔记 | CDQ分治
目录 前言 啥是CDQ啊(它的基本思想) 例题 后记 参考博文 前言 博主太菜了 学习快一年的OI了 好像没有什么会的算法 更寒碜的是 学一样还不精一样TAT 如有什么错误请各位路过的大佬指出啊感谢! ...
- PAT甲题题解-1068. Find More Coins (30)-dp,01背包
一开始没多想,虽然注意到数据N<=10^4的范围,想PAT的应该不会超时吧,就理所当然地用dfs做了,结果最后一组真的超时了.剪枝啥的还是过不了,就意识到肯定不是用dfs做了.直到看到别人说用0 ...
- 实验---反汇编一个简单的C程序(杨光)
反汇编一个简单的C程序 攥写人:杨光 学号:20135233 ( *原创作品转载请注明出处*) ( 学习课程:<Linux内核分析>MOOC课程http://mooc.study.163 ...
- 20135337朱荟潼 Linux第七周学习总结——可执行程序的装载
朱荟潼 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 第七周 Linu ...
- C#获取每月最后一天或者最末一天的方法
/// <summary> /// 取得某月的第一天 /// </summary> /// <param name="datetime">要取得 ...