【C语言】实现求两个数的最大公约数【四种算法】
题目
给定两个数,求这两个数的最大公约数
例如:
输入:20 40
输出:20
解题思路
最大公约数:即两个数据中公共约数的最大者
求解的方式比较多,暴力穷举、辗转相除法、更相减损法、Stein算法算法
方法一:辗转相除法(推荐此方法)
思路:
例子:18和24的最大公约数
第一次:a = 18 b = 24 c = a%b = 18%24 = 18
循环中:a = 24 b=18
第二次:a = 24 b = 18 c = a%b = 24%18 = 6
循环中:a = 18 b = 6
第三次:a = 18 b = 6 c = a%b = 18%6 = 0
循环结束
此时b中的内容即为两个数中的最大公约数
#include <stdio.h>int main()
{int m = 0;int n = 0;int tmp = 0;printf("请输入两个整数: ");scanf("%d %d", &m, &n);while (tmp = m % n){m = n;n = tmp;}printf("最大公约数为:%d\n", n);return 0;
}
方法二:暴力穷举法
如果大数可以整除小数,那么最大公约数为小数。
如果不能整除小数,那么这两个数就按大到小依次对比小数小的数求余,遇到都能够整除的,就是最大公约数。
#include<stdio.h>
#include<windows.h>
#pragma warning(disable:4996)
int main(){//暴力穷举法int a = 0;int b = 0;printf("请输入两个整数:");scanf("%d%d", &a, &b);if (a >= b){int i = 0;for (i = b; i >= 1; i--){if (a%i == 0 && b%i == 0){printf("最大公约数为:%d\n", i);break;}}}else{int j = 0;for (j = a; j >= 1; j--){if (a%j == 0 && b%j == 0){printf("最大公约数为:%d\n", j);break;}}}system("pause");return 0;
}
方法三:更相减损法
当两个数相等时,最大公约数为他们其中任意一个;
当两个数不相等时,用大数减小数得到的差和之前的那个小数再次相减,直到两个数相等,相等的两个中,任意一个都是最大公约数。
#include<stdio.h>
#include<windows.h>
#pragma warning(disable:4996)
int main(){//更相减损法int a = 0;int b = 0;printf("请输出两个整数:");scanf("%d%d", &a, &b);while ((a - b)!=0){if (a > b){a = a - b;}else{b = b - a;}}printf("最大公约数为:%d\n", b);system("pause");return 0;
}
方法四:Stein算法
步骤:
step1:两数均为偶数时将其同时除以2至少一数为奇数为止,记录除掉的所有公因数2的乘积k;
step2:如果仍有一数为偶数,连续除以2直至该数为奇数为止;
step3:用更相减损法(辗转相减法),即GCD(a,b)=GCD(a-b,b),或辗转相除法求出两奇数的最大公约数d;
step4:原来两数的最大公约数即为d*k。
#include<stdio.h>
#include<windows.h>
#pragma warning(disable:4996)
int main(){//Stein算法int a = 0;int b = 0;printf("请输入两个整数:");scanf("%d%d", &a, &b);int gcd = 0;int k = 1;while ((!(a & 1)) && (!(b & 1))){ //step1;k <<= 1; //用k记录全部公因子2的乘积 ;a >>= 1;b >>= 1;}while (!(a & 1))a >>= 1; //step2;while (!(b & 1))b >>= 1;if (a<b) a ^= b, b ^= a, a ^= b; //交换,使a为较大数; while (a != b){ //step3;a -= b;if (a<b) a ^= b, b ^= a, a ^= b;}gcd = k*a;printf("最大公约数为:%d\n", gcd);system("pause");return 0;
}
【C语言】实现求两个数的最大公约数【四种算法】相关推荐
- c语言如何求两个数最大公约数,c语言如何求两个数的最大公约数
c语言求两个数的最大公约数的方法:首先新建一个C语言源程序,并直接输入两个正整数a和b:然后取a,b这两个数中的较小值,存放到变量n中:接着从两个数a和b中的较小数开始,依次逐个减小1:.最后点击工具 ...
- 【C语言】求两个数的最大公约数
求最大公约数的一个常用方法就是辗转相除法,举一个例子:求24和18的最大公约数:24/18=1余数是6, 18/6=3余数是0,从这里可以看出我们将最开始的被除数和除数,除数和余数进行了调换.当除数除 ...
- js习题(求两个数的和的四种方法)
不推荐使用递归,递归使用太多会导致栈溢出 <!DOCTYPE html> <html lang="en"><head><meta char ...
- C语言试题七十三之请编写函数求两个数的最大公约数
1. 题目 编写函数:求两个数的最大公约数. 如果有一个自然数a能被自然数b整除,则称a为b的倍数,b为a的约数.几个自然数公有的约数,叫做这几个自然数的公约数.公约数中最大的一个公约数,称为这几个自 ...
- php怎么求最小公倍数,C++_详解C语言求两个数的最大公约数及最小公倍数的方法,求两个正整数的最大公约数nbs - phpStudy...
详解C语言求两个数的最大公约数及最小公倍数的方法 求两个正整数的最大公约数 思路:这是一个很基本的问题,最常见的就是两种方法,辗转相除法和辗转相减法.通式分别为 f(x, y) = f(y, x%y) ...
- c语言求两个数的最小公倍数辗转相除法,C语言辗转相除法求2个数的最小公约数...
辗转相除法最大的用途就是用来求两个数的最大公约数. 用(a,b)来表示a和b的最大公约数. 有定理: 已知a,b,c为正整数,若a除以b余c,则(a,b)=(b,c). (证明过程请参考其它资料) 例 ...
- c语言用迭代法求最大公约数,用迭代法求两个数的最大公约数和最小公倍数
c语言论文 用迭代法求两个数的最大公约数和最小公倍数 化工09110605 摘要:迭代法是一种循环控制语句和循环结构程序的设计方法.在计算机解决问 题的时候,总希望从复杂的问题中找到规律,并归结为简单 ...
- c语言中两个数最大公约数怎么求,C语言求两个数中最大公约数
在C语言中如何求两个数的最大公约数呢?下面用三种方法进行求解. 方法一:穷举法. 先比较两个数的大小,然后找出较小数t,最后判断t为何值时两个数都能整除,此方法效率较低. 代码如下:#include ...
- 暴力 gcd __gcd (详解)C语言求两个数的最大公约数
首先我们要先知道gcd是什么东西? GCD作为缩写意义有多种.它通常表示最大公约数(greatest common divisor,简写为gcd:或highest common factor,简写为h ...
- 程序员数学基础【四、取模应用-判断奇偶数、判断素数、求两个数的最大公约数、水仙花数】(Python版本)
测试使用语言:[Python] 由于此类语言入门非常容易,哪怕初中生亦可以,并且本科/研究生写论文.做实验多数所用语言都是[Python]故而选择此语言. 代码运行平台:[win10 x64] 代码环 ...
最新文章
- [转] 使用Spring MVC构建REST风格WEB应用
- MP4移动商学院―――管理者贴身教练!
- 基于Mac自带nginx、php,配置php服务器
- 获取 iPhone 上联系人姓名、电话、邮件的代码
- mysql那本书适合初学者_3本书适合初学者
- oracle数据库连接时报12514_连接Oracle数据库时报ORA-12541:TNS:无监听程序的图文解决教程...
- 为什么有些人退休后,一下子衰老了很多?
- 人脸对齐(十四)--LPFA
- 用 eric6 与 PyQt5 实现python的极速GUI编程(系列03)---- Drawing(绘图)(1)-- 绘写文字...
- 程序员真实写真:35岁前成功的12条黄金法则 (转)
- SilverLight3 cool开发(二) Mac Dock栏
- [C++]C++连接MySQL,封装为class(兼容x86和x64)
- 区块链主流共识算法全面解析
- Informatic学习总结_day01
- 拼多多增长黑客模式实战
- 这本记述40年前历史的游戏书,预言的却是当下的事
- 新浪与腾讯的开放平台对比
- vs2010生成的exe更改icon
- 7个免费PDF转换软件推荐
- 三十、非谓语动词_作状语