首页 > 其他 > 详细

辗转相除法

时间:2016-09-30 20:53:45      阅读:213      评论:0      收藏:0      [点我收藏+]

辗转相除法求最大公约数的算法:

第一步:if bnum > snum,将bnum和snum的值呼唤,使得大的数bnum为被除数;

第二步:while(bnum/snum的余数rest!=0){

bnum=snum;

snum=rest;

}

最后,输出最大公约数rest;最小公倍数l=bnum*snum/rest;

 

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <string.h>
 4 int main()
 5 {
 6     int hcf(int,int);
 7     int lcf(int,int,int);
 8     int bnum,snum,h,l;
 9     printf("请输入两个数:\n");
10     scanf("%d %d",&bnum,&snum);
11     printf("%d和%d的最大公约数和最小公倍数分别是:",bnum,snum);
12     h=hcf(bnum,snum);
13     printf("%d和",h);
14     l=lcf(bnum,snum,h);
15     printf("%d",l);
16     system("pause");
17     return 0;
18 }
19 int hcf(int bnum,int snum){
20     int temp,rest;
21     if(bnum<snum){
22         temp=bnum;
23         bnum=snum;
24         snum=temp;
25     }
26     while((rest=bnum%snum)!=0){//辗转相除法
27         bnum=snum;
28         snum=rest;
29     }
30     return(snum);
31 }
32 int lcf(int bnum,int snum,int h){
33     return (bnum * snum /h);
34 }

 

辗转相除法

原文:http://www.cnblogs.com/crystalmoore/p/5924527.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!