設計一個表示分數的類Fraction。這個類用兩個int類型的變量分別表示分子和分母。 這個類的構造函數是: Fraction(int a,
int b) 構造一個a/b的分數。 這個類要提供以下的功能: double toDouble(); 將分數轉換爲double
Fraction plus(Fraction r);
將自己的分數和r的分數相加,產生一個新的Fraction的對象。注意小學四年級學過兩個分數如何相加的哈。 Fraction
multiply(Fraction r); 將自己的分數和r的分數相乘,產生一個新的Fraction的對象。 void print();
將自己以“分子/分母”的形式輸出到標準輸出,並帶有回車換行。如果分數是1/1,應該輸出1。當分子大於分母時,不需要提出整數部分,即31/30是一個正確的輸出
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
Fraction a = new Fraction(in.nextInt(), in.nextInt());
Fraction b = new Fraction(in.nextInt(), in.nextInt());
a.print();
b.print();
a.plus(b).print();
a.multiply(b).plus(new Fraction(5, 6)).print();
a.print();
b.print();
in.close();
}
}
class Fraction {
private int a, b;
public Fraction(int a, int b) {
this.a = a;
this.b = b;
}
double toDouble() {
return 1.0 * a / b;
}
public Fraction plus(Fraction r) {
int i = this.a * r.b + this.b * r.a;
int j = this.b * r.b;
return new Fraction(i, j);
}
public Fraction multiply(Fraction r) {
int i = this.a * r.a;
int j = this.b * r.b;
return new Fraction(i, j);
}
void print() {
int a, b;
int t;
a = this.a;
b = this.b;
while (b != 0) { //輾轉相除法求最大公約數
t = a % b;
a = b;
b = t;
}
this.a /= a;
this.b /= a;
if (this.a == this.b)
System.out.println(1);
else
System.out.println(this.a + "/" + this.b);
}
}