C语言求最大公约数和最小公倍数算法总结.
巡山小妖精
664次浏览
2021年02月01日 12:32
最佳经验
本文由作者推荐
硬笔书法作品欣赏-鲁滨孙漂流记读后感
C
语言求最大公约数和最小公倍数算法总结
单位:隆回县职业中等专业学校
作者:刘小华
摘
要:介绍自己通过学习使用
C
语言求任意两个数的最大公约数和最小公倍数的基本算法思想、
算法过程、代码实现以及分析 比较。
关键词:
C
语言
算法
最大公约数
最小公倍数
中图分类号:
TP312
文献标识码:
A
The
algorithm
summarization
of
evaluating
the
highest
common
divisor
and
the
lowest
common
multiple in C Language
Zhao
Ye
Lin
Tutor Teacher
:
Liu Xiao Hua
Abstract
:
Introduction
to
the
algorithm
basic
thought,
algorithm
process
and
code
realization
and
its
analysing comparison in terms of evaluating the highest common divisor and the lowest common multiple
of any two positive integers by learning to using C Language
Keywords
:
C
Language
algorithm
the highest common divisor
the lowest common multiple
C
语言求最大公约数和最小公倍数可以说是
C
语言编程学习中一个 重点和难点,它常常作为计
算机专业学生参加各种考试必须要把握的内容。其算法方面除常用的辗转相除 法外、还可以根据数
学定义法、递归调用法等。下面结合我学习以来的笔记整理、总结几种常用的方法进 行比较,以便
能够更好的理解、应用、共勉。
前提:假设求任意两个整数的最大公约数和最小公倍数,采用函数调用形式进行。
1
、辗转相除法
辗转相除法(又名欧几里德法)
C
语言中 用于计算两个正整数
a,b
的最大公约数和最小公倍数,
实质它依赖于下面的定理:< br>
a
b=0
gcd(a,b) =
gcd(b,a mod b)
b!=0
根据这一定理可以采用函数嵌套调用和递归调用形式进行求两个数的最大公约数和最 小公倍数
,
现分别叙述如下:
①、函数嵌套调用
其算法过程为:
前提
:
设两数为
a,b
设其中
a
做被除数
,b
做除数,
temp
为余数
1
、大数放
a
中、小数放
b
中;
2
、求
a/b
的余数;
3
、若
temp=0
则
b
为最大公约数;
4
、如果
temp!=0
则把
b
的值给
a
、temp
的值给
a
;
5
、返回第第二步;
代码:
int divisor (int a,int b)
/*
自定义函数求两数的最大公约数
*/
{
int
temp;
/*
定义整型变量
*/
if(a
/*
通过比较求出两个数中的最大值和最小值
*/
{ temp=a;a=b;b=temp;}
/*
设置中间变量进行两数交换
*/
while(b!=0)
/*
通过循环求两数的余数,直到余数为
0*/
{
temp=a%b;
a=b;
/*
变量数值交换
*/
b=temp;
}
return (a);
/*
返回最大公约数到调用函数处
*/
}
int multiple (int a,int b)
/*
自定义函数求两数的最小公倍数
*/
{
int divisor (int a,int b);
/*
自定义函数返回值类型
*/
int temp;
temp=divisor(a,b);
/*
再次调用自定义函数,求出最大公约数
*/
return
(a*b/temp);
/*
返回最小公倍数到主调函数处进行输出
*/
}
#include
/*
输入输出类头文件
*/
main()
{
int m,n,t1,t2;
/*
定义整型变量
*/
printf(
*
提示输入两个整数
*/