首页 > 其他 > 详细

求最大公约数和最小公倍数的几种方法

时间:2017-07-23 19:02:34      阅读:283      评论:0      收藏:0      [点我收藏+]

最大公约数

  1. 常规方法
  2. 辗转相除法
  3. 递归法
  4. 三目运算符 + 递归

最小公倍数

  1. 常规方法
  2. 利用最大公约数求解

 

示例代码:

 1 #include<iostream>
 2 using namespace std;
 3 
 4 //最大公约数 
 5 //(1)常规方法 
 6 void gcd1(int a, int b)
 7 {
 8     int minNum = min(a, b);    
 9     for (int i = minNum; i >= 1; i--)
10     {
11         if (a % i == 0 && b % i == 0)
12         {
13             printf("%d\n", i);
14             break;
15         }
16     }
17 }
18 
19 //(2)辗转相除法 
20 void gcd2(int a, int b)
21 {
22     int tmp;
23     while (true) {
24         if (a == 0) 
25         {
26             printf("%d\n", b);
27             break;
28         }
29         
30         tmp = a;
31         a = b % a;
32         b = tmp;
33     }    
34 }
35 
36 //(3)递归法 
37 int gcd3(int a, int b)
38 {
39     if (b == 0)
40         return a;
41     else
42         return gcd3(b, a % b);
43 }
44 
45 //(4)三目运算符 + 递归 
46 int gcd4(int a, int b)
47 {
48     return (b == 0) ? a : gcd4(b, a % b);
49 }
50 
51 //最小公倍数
52 //(1)常规方法 
53 int lcm1(int a, int b)
54 {
55     int maxNum = max(a , b);
56     int pro = a * b;
57     for(int i = maxNum; i <= pro; i++)
58     {
59         if( i % a == 0 && i % b == 0)
60         {
61             printf("%d\n", i);
62             break;
63         }
64     }
65 }
66 
67 //(2)利用最大公约数求解 
68 int lcm2(int a, int b)
69 {
70     return a * b / gcd4(a , b); 
71 }
72 
73 int main()
74 {
75     int a = 15, b = 12;
76     printf("15 和 12 的最大公约数为:\n");
77     gcd1(a, b);
78     
79     gcd2(a, b);
80     
81     int t = gcd3(a, b);
82     printf("%d\n", t);
83     
84     t = gcd4(a, b);
85     printf("%d\n", t);
86     
87     printf("15 和 12 的最小公倍数为:\n");
88     lcm1(a, b);
89     
90     t = lcm2(a ,b);
91     printf("%d", t);     
92     
93     return 0;
94 }

 

运行结果:

技术分享

求最大公约数和最小公倍数的几种方法

原文:http://www.cnblogs.com/cao-lei/p/7225633.html

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