题目

给定两个数,求这两个数的最大公约数

例如:

输入: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语言】实现求两个数的最大公约数【四种算法】相关推荐

  1. c语言如何求两个数最大公约数,c语言如何求两个数的最大公约数

    c语言求两个数的最大公约数的方法:首先新建一个C语言源程序,并直接输入两个正整数a和b:然后取a,b这两个数中的较小值,存放到变量n中:接着从两个数a和b中的较小数开始,依次逐个减小1:.最后点击工具 ...

  2. 【C语言】求两个数的最大公约数

    求最大公约数的一个常用方法就是辗转相除法,举一个例子:求24和18的最大公约数:24/18=1余数是6, 18/6=3余数是0,从这里可以看出我们将最开始的被除数和除数,除数和余数进行了调换.当除数除 ...

  3. js习题(求两个数的和的四种方法)

    不推荐使用递归,递归使用太多会导致栈溢出 <!DOCTYPE html> <html lang="en"><head><meta char ...

  4. C语言试题七十三之请编写函数求两个数的最大公约数

    1. 题目 编写函数:求两个数的最大公约数. 如果有一个自然数a能被自然数b整除,则称a为b的倍数,b为a的约数.几个自然数公有的约数,叫做这几个自然数的公约数.公约数中最大的一个公约数,称为这几个自 ...

  5. php怎么求最小公倍数,C++_详解C语言求两个数的最大公约数及最小公倍数的方法,求两个正整数的最大公约数nbs - phpStudy...

    详解C语言求两个数的最大公约数及最小公倍数的方法 求两个正整数的最大公约数 思路:这是一个很基本的问题,最常见的就是两种方法,辗转相除法和辗转相减法.通式分别为 f(x, y) = f(y, x%y) ...

  6. c语言求两个数的最小公倍数辗转相除法,C语言辗转相除法求2个数的最小公约数...

    辗转相除法最大的用途就是用来求两个数的最大公约数. 用(a,b)来表示a和b的最大公约数. 有定理: 已知a,b,c为正整数,若a除以b余c,则(a,b)=(b,c). (证明过程请参考其它资料) 例 ...

  7. c语言用迭代法求最大公约数,用迭代法求两个数的最大公约数和最小公倍数

    c语言论文 用迭代法求两个数的最大公约数和最小公倍数 化工09110605 摘要:迭代法是一种循环控制语句和循环结构程序的设计方法.在计算机解决问 题的时候,总希望从复杂的问题中找到规律,并归结为简单 ...

  8. c语言中两个数最大公约数怎么求,C语言求两个数中最大公约数

    在C语言中如何求两个数的最大公约数呢?下面用三种方法进行求解. 方法一:穷举法. 先比较两个数的大小,然后找出较小数t,最后判断t为何值时两个数都能整除,此方法效率较低. 代码如下:#include ...

  9. 暴力 gcd __gcd (详解)C语言求两个数的最大公约数

    首先我们要先知道gcd是什么东西? GCD作为缩写意义有多种.它通常表示最大公约数(greatest common divisor,简写为gcd:或highest common factor,简写为h ...

  10. 程序员数学基础【四、取模应用-判断奇偶数、判断素数、求两个数的最大公约数、水仙花数】(Python版本)

    测试使用语言:[Python] 由于此类语言入门非常容易,哪怕初中生亦可以,并且本科/研究生写论文.做实验多数所用语言都是[Python]故而选择此语言. 代码运行平台:[win10 x64] 代码环 ...

最新文章

  1. [转] 使用Spring MVC构建REST风格WEB应用
  2. MP4移动商学院―――管理者贴身教练!
  3. 基于Mac自带nginx、php,配置php服务器
  4. 获取 iPhone 上联系人姓名、电话、邮件的代码
  5. mysql那本书适合初学者_3本书适合初学者
  6. oracle数据库连接时报12514_连接Oracle数据库时报ORA-12541:TNS:无监听程序的图文解决教程...
  7. 为什么有些人退休后,一下子衰老了很多?
  8. 人脸对齐(十四)--LPFA
  9. 用 eric6 与 PyQt5 实现python的极速GUI编程(系列03)---- Drawing(绘图)(1)-- 绘写文字...
  10. 程序员真实写真:35岁前成功的12条黄金法则 (转)
  11. SilverLight3 cool开发(二) Mac Dock栏
  12. [C++]C++连接MySQL,封装为class(兼容x86和x64)
  13. 区块链主流共识算法全面解析
  14. Informatic学习总结_day01
  15. 拼多多增长黑客模式实战
  16. 这本记述40年前历史的游戏书,预言的却是当下的事
  17. 新浪与腾讯的开放平台对比
  18. vs2010生成的exe更改icon
  19. 7个免费PDF转换软件推荐
  20. 三十、非谓语动词_作状语

热门文章

  1. Android无障碍 点击,无障碍点击器下载-致无障碍点击 安卓版v1.0-pc6手机下载
  2. unity点击按钮控制界面开关
  3. OA系统前台模板-html
  4. vue打包部署,解决更新版本清理缓存问题
  5. VUE 前端SSO单点登录
  6. 广告狂人第一至七季/全集Mad Men迅雷下载
  7. 后端返回数组对象(id重复)来去重并保留第一个
  8. Ag44团簇以及衍生团簇(银纳米团簇直径1-2nm)
  9. Taro-ui 常用 UI 组件库说明
  10. HCIE-Cloud Computing LAB备考第二步:实战解题–第五题:论述一--双活容灾设计--记忆宫殿