最大公約數

 1 /*
 2     Name: 求最大公約數的三種方法 
 3     Copyright: 
 4     Author: 潤青 
 5     Date: 01/11/18 10:57
 6     Description: 窮舉法、展轉相除法、相減法 
 7 */
 8 #include<stdio.h>
 9 void gcd1(int m,int n);
10 void gcd2(int m,int n); 
11 void gcd3(int m,int n);  
12 int m,n; 
13 int main(){
14     int sum=10; 
15     while(sum--){
16         scanf("%d%d",&m,&n);
17         gcd1(m,n);
18         gcd2(m,n);
19         gcd3(m,n);
20     } 
21     
22     return 0; 
23 }
24 void gcd1(int m,int n){
25     //printf("窮舉法\n\n"); 
26     int min;
27     int mod1,mod2;
28     int count=0; 
29     if(m>=n)
30         min=n;
31     else
32         min=m;
33     while(1){
34         mod1=m%min;
35         mod2=n%min;
36         count++;
37         if(mod1==0&&mod2==0){
38             printf("最大公約數:%d\n",min);
39             printf("count=%d\n",count); 
40             break; 
41         } 
42         else{
43             min--;
44         }  
45     }
46 }
47 void gcd2(int m,int n){
48     //printf("展轉相除法\n\n"); 
49     int max,min;
50     int count = 1; 
51     if(m>=n){
52         max=m;
53         min=n; 
54     } 
55     else{
56         max=n;
57         min=m; 
58     }
59       int mod=max%min;
60     while(mod!=0){
61         max=min;
62         min=mod;
63         mod=max%min; 
64         count++; 
65     }
66     printf("最大公約數:%d\n",min);
67     printf("count=%d\n",count); 
68 }
69 void gcd3(int m,int n){
70     //printf("相減法\n\n"); 
71     int max,min;
72     int count = 1; 
73     if(m>=n){
74         max=m;
75         min=n; 
76     } 
77     else{
78         max=n;
79         min=m; 
80     }
81     int sub=max-min;
82     while(sub!=0){
83         if(min>=sub){
84             max=min;
85             min=sub; 
86         } 
87         else{
88             max=sub;
89             min=min; 
90         } 
91         sub=max-min;
92         count++; 
93     }
94     printf("最大公約數:%d\n",min);
95     printf("count=%d\n",count); 
96 } 
相關文章
相關標籤/搜索