c语言最大公约数及最小公倍数的详解
今天我打算把,学习到的一些知识整理一下,方便给以后的学弟学妹做一个参考!
这一次是关于最大公约数和最小公倍数的知识:这是百度关于最大公约数的介绍
感谢我的一位学姐的博文,让我能够更快的明白!
求最小公倍数算法:
最小公倍数=两整数的乘积÷最大公约数
求最大公约数算法:
(1)辗转相除法
有两整数a和b:
① a%b得余数c
② 若c=0,则b即为两数的最大公约数
③ 若c≠0,则a=b,b=c,再回去执行①
例如求27和15的最大公约数过程为:
27÷15 余1215÷12余312÷3余0因此,3即为最大公约数
1 #include<stdio.h>
2 int main() /* 辗转相除法求最大公约数 */
3 {
4 int m, n, a, b, t, c;
5 printf("Input two integer numbers:\n");
6 scanf("%d%d", &a, &b);
7 m=a; n=b;
8 while(b!=0) /* 余数不为0,继续相除,直到余数为0 */
9 { c=a%b;
a=b;
b=c;
10 printf("The largest common divisor:%d\n", a);
11 printf("The least common multiple:%d\n", m*n/a);
12 }
⑵ 相减法
有两整数a和b:
① 若a>b,则a=a-b
② 若a小于b,则b=b-a
③ 若a=b,则a(或b)即为两数的最大公约数
④ 若a≠b,则再回去执行①
例如求27和15的最大公约数过程为:
27-15=12( 15>12 ) 15-12=3( 12>3 )
12-3=9( 9>3 ) 9-3=6( 6>3 )
6-3=3( 3==3 )
因此,3就是最大公约数:
1 #include<stdio.h>
2 int main ( ) /* 相减法求最大公约数 */
3 {
4 int m, n, a, b, c;
5 printf("Input two integer numbers:\n");
6 scanf ("%d,%d", &a, &b);m=a; n=b;
7 /* a, b不相等,大数减小数,直到相等为止。*/
8 while ( a!=b)
9 if (a>b)
a=a-b;
10 else b=b-a;
11 printf("The largest common divisor:%d\n", a);
12 printf("The least common multiple:%d\n", m*n/a);
13 }
(3)穷举法:
有两整数a和b:
① i=1
② 若a,b能同时被i整除,则t=i
③ i++
④ 若 i <= a(或b),则再回去执行②
⑤ 若 i > a(或b),则t即为最大公约数,结束
改进:
① i= a(或b)
② 若a,b能同时被i整除,则i即为最大公约数,
结束
③ i--,再回去执行②
有两整数a和b:
① i=1
② 若a,b能同时被i整除,则t=i
③ i++
④ 若 i <= a(或b),则再回去执行②
⑤ 若 i > a(或b),则t即为最大公约数,结束
改进:
① i= a(或b)
② 若a,b能同时被i整除,则i即为最大公约数,
结束
③ i--,再回去执行②
1 #include<stdio.h>
2 int main () /* 穷举法求最大公约数 */
3 {
4 int m, n, a, b, i, t;
5 printf("Input two integer numbers:\n");
6 scanf ("%d,%d", &a, &b);m=a; n=b;
7 for (i=1; i<= a; i++)
8 if ( a%i == 0 && b%i ==0 ) t=i;
9 printf("The largest common divisor:%d\n", t);
10 printf("The least common multiple:%d\n", m*n/t);
11 }
12 /* 改进后的
13 for (t= a; t>0; t-- )
14 if ( a%t == 0 && b%t ==0 ) break;
15 */
其实你还可以这样写出:
1 //穷举法求最小公倍数
2 for (i= a; ; i++ )
3 if ( i % a == 0 && i % b ==0 ) break;
4 printf("The least common multiple:%d\n", i )
5
6 //多个数的最大公约数和最小公倍数
7 for (i= a; i>0; i-- )
8 if (a%i==0&&b%i==0&&c%i==0) break;
9 printf("The largest common divisor:%d\n", i);
10 for (i= a; ; i++ )
11 if (i%a==0&&i%b==0&&i% c==0) break;
12 printf("The least common multiple:%d\n", i )
“`
不知道你们有没有发现·一个很奇怪的事实就是:
我们求最大公约数的时候(i要做的的是:i<=a;就是说明其最大公约数,应该小于a的值;
下面就是说一下关于最小公倍数了,它与最大公约数恰恰相反,i>=a ;这个也能够说明其
最小公倍数应该是要大于a的值)
努力是因为不希望那些在乎我的人失望!
如果你们感觉我写的还可以,就请关注一下博主,毕竟博主创作也好辛苦的!
c语言最大公约数及最小公倍数的详解的更多相关文章
- Go语言的GOPATH与工作目录详解
这篇文章主要介绍了Go语言的GOPATH与工作目录详解,本文详细讲解了GOPATH设置.应用目录结构.编译应用等内容,需要的朋友可以参考下 GOPATH设置 go 命令依赖一个重要的环境变量:$GOP ...
- 【转载】C语言itoa()函数和atoi()函数详解(整数转字符C实现)
本文转自: C语言itoa()函数和atoi()函数详解(整数转字符C实现) 介绍 C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串. int/float to ...
- EF+LINQ事物处理 C# 使用NLog记录日志入门操作 ASP.NET MVC多语言 仿微软网站效果(转) 详解C#特性和反射(一) c# API接受图片文件以Base64格式上传图片 .NET读取json数据并绑定到对象
EF+LINQ事物处理 在使用EF的情况下,怎么进行事务的处理,来减少数据操作时的失误,比如重复插入数据等等这些问题,这都是经常会遇到的一些问题 但是如果是我有多个站点,然后存在同类型的角色去操作 ...
- go语言之行--结构体(struct)详解、链表
一.struct简介 go语言中没有像类的概念,但是可以通过结构体struct实现oop(面向对象编程).struct的成员(也叫属性或字段)可以是任何类型,如普通类型.复合类型.函数.map.int ...
- C语言 后缀自增的优先级详解
// ++ 后缀自增与取地址& ,提领 * (指针里的操作符)的优先级比较 #include<stdio.h> #include<stdlib.h> #include& ...
- C语言 printf格式化输出,参数详解
有关输出对齐 int main(int argc, char* argv[]){ char insertTime[20] = {"1234567890"}; double in ...
- C语言核心之数组和指针详解
指针 相信大家对下面的代码不陌生: int i=2; int *p; p=&i;这是最简单的指针应用,也是最基本的用法.再来熟悉一下什么是指针:首先指针是一个变量,它保存的并不是平常的数据,而 ...
- C语言itoa()函数和atoi()函数详解(整数转字符C实现)
1.int/float to string/array: C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串,下面列举了各函数的方法及其说明. ● itoa():将 ...
- C语言itoa()函数和atoi()函数详解(整数转字符)
http://c.biancheng.net/cpp/html/792.html C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串. 以下是用itoa()函数将整 ...
随机推荐
- 基于 HTML5 Canvas 的工控机柜 U 位动态管理
前言 U 是一种表示服务器外部尺寸的单位,是 unit 的缩略语,详细的尺寸由作为业界团体的美国电子工业协会(EIA)所决定.之所以要规定服务器的尺寸,是为了使服务器保持适当的尺寸以便放在铁质或铝质的 ...
- Vue 仿B站滑动导航
仿照B站制作的滑动导航功能,进行了部分优化,例如可定制默认选中元素,并将选中元素居中显示,可动态更改数据,可定制回调函数取的下标和选中元素内容,可根据需求制作N级联动 已开发成插件,使用方法与源码请前 ...
- Spring Security简明实践及相关国际化处理
别人的都是最佳实践,因为我目前的设置没有按照参考文档推荐,还是采用DelegatingFilterProxy,所以我只能说简明实践.先贴我的applicationContext-security.xm ...
- Dynamic 中修改实体中主字段的长度
select EntityId,* from MetadataSchema.Entity where Name='dji_incidentaddress' SELECT TOP 100 [Attrib ...
- Windows下Markdown软件的选择
从开始Java学习这个系列的同时,我也开始改用Markdown而不是无比蛋疼的博客园默认编辑器来进行博客管理.但是Windows下想找一个比较好的Markdown编辑器蛮困难的,可以说专门的Markd ...
- 【ASP.NET MVC系列】浅谈ASP.NET MVC八大类扩展(上篇)
lASP.NET MVC系列文章 [01]浅谈Google Chrome浏览器(理论篇) [02]浅谈Google Chrome浏览器(操作篇)(上) [03]浅谈Google Chrome浏览器(操 ...
- RNN(Recurrent Neural Network)的几个难点
1. vanish of gradient RNN的error相对于某个时间点t的梯度为: \(\frac{\partial E_t}{\partial W}=\sum_{k=1}^{t}\frac{ ...
- Shell 起停脚本 专题
To list any process listening to the port 8080: lsof -i:8080To kill any process listening to the por ...
- Docker for windows on VMware
工作环境 操作系统:Windows 10 Pro x64 Hyper-V:已卸载. VMware:已安装. Virtual Box:无安装. 前言 鉴于Hyper-V在Windows桌面系统下的&qu ...
- 彻底弄懂HTTP缓存机制及原理
前言 Http 缓存机制作为 web 性能优化的重要手段,对于从事 Web 开发的同学们来说,应该是知识体系库中的一个基础环节,同时对于有志成为前端架构师的同学来说是必备的知识技能. 但是对于很多前端 ...