(3) 编写两个类:A和B,A创建的对象可计算两个正整数的最大公约数,B 创建的对象可以计算两个数的最小公倍数。要求B类中有一个成员变量用A类声 明的对象。
上面的题目我写出来的程序,然后就最大公因数能运行出结果,最小公倍数就出不来,但是把最小公倍数的代码单独拿出去就可以运行,求解答
package SY2;
public class CDQ2_2_3_A {
public int a;
public int b;
public void set(int a, int b) {
this.a = a;
this.b = b;
}
//求最大公因数方法
public int maxNum() {
int min = (this.a < this.b)?a:b;
int max = 0;
for (int i = 1; i <= min; i++){
if (a%i==0 && b%i==0){
if (i > max){
max = i;
}
}
}
return max;
}
}
package SY2;
import java.util.*;
public class CDQ2_2_3_B {
//求最小公倍数方法
public int minNum() {
CDQ2_2_3_A n = new CDQ2_2_3_A();
int max = (n.a > n.b)?n.a:n.b;
int min = 0;
for (int i = n.a * n.b; i >= max; i--){
if (i%n.a==0 && i%n.b==0){
min = i;
}
}
return min;
}
//主方法
public static void main (String [] args){
CDQ2_2_3_A n = new CDQ2_2_3_A();
CDQ2_2_3_B n1 = new CDQ2_2_3_B();
Scanner sc = new Scanner (System.in);
System.out.println("请输入第一个数");
int a = sc.nextInt();
System.out.println("请输入第二个数");
int b = sc.nextInt();
n.set(a,b);//传入两个整数
System.out.println ("最大公因数:"+n.maxNum());
System.out.println ("最小公倍数:"+n1.minNum());
}
}