題目:輸入兩個正整數 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 }