Java基礎50題test6—求最大公約數和最小公約數


題目:輸入兩個正整數 m 和 n,求其最大公約數和最小公倍數。

程序分析:利用輾除法。

 

 

 1 import java.util.*;
 2 
 3 public class Test6 {
 4 
 5     /**
 6      * 輸入兩個正整數 m 和 n,求其最大公約數和最小公倍數
 7      * 利用輾轉相除法
 8      */
 9     public static void main(String[] args) {
10         Scanner in = new Scanner(System.in);
11         System.out.println("請輸入兩個整數(以空格隔開):");
12         int m = in.nextInt();
13         int n = in.nextInt();
14         in.close();
15         int divisor = GCdivisor(m,n);        //最大公約數
16         int multiple= LCmultiple(m,n);       //最小公倍數
17         System.out.println("最大公約數為:"+divisor);
18         System.out.println("最小公倍數為:"+multiple);
19     }
20     
21     //最小公倍數函數:最小公倍數=兩數之積/最大公約數
22     private static int LCmultiple(int m, int n) {
23         return (m*n)/GCdivisor(m,n);
24     }
25 
26     //最大公約數函數
27     private static int GCdivisor(int m, int n) {
28         int temp;
29         if(m<n)
30         {
31             temp = m;
32             m = n;
33             n = temp;
34         }
35         if(n == 0)      //余數為零
36             return m;   //此時m為上一次除法中較小的數即n
37         else
38             return GCdivisor(n, m%n);//遞歸調用
39     }
40 
41 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM