当前位置:主页   - 电脑 - 程序设计 - JAVA
Java 小例子:模拟分数的类 Fraction
来源:网络   作者:   更新时间:2012-06-13
收藏此页】    【字号    】    【打印】    【关闭

  这里是一个模拟分数运算的例子:Fraction 类。分数运算完后要用最大公约数除分子分母。所以这里也有个用辗转相除法求最大公约数的例子。另外在构造 Fraction 对象时如果分母为零将会抛出异常,这也是必要的检查。

public class FractionTest {  
   
    public static void main(String[] args) {  
        Fraction a = new Fraction(7, 32);  
        Fraction b = new Fraction(13, 32);  
        System.out.println(a + " + " + b + " = " + a.add(b) + "(" + a.add(b).doubleValue() + ")");  
        System.out.println(a + " - " + b + " = " + a.minus(b) + "(" + a.minus(b).doubleValue() + ")");  
        System.out.println(a + " * " + b + " = " + a.multiply(b) + "(" + a.multiply(b).doubleValue() + ")");  
        System.out.println(a + " / " + b + " = " + a.devide(b) + "(" + a.devide(b).doubleValue() + ")");  
    }  
}  
   
// 分数  
class Fraction {  
    private int numerator;      // 分子  
   
    private int denominator;    // 分母  
   
    Fraction(int numerator, int denominator) {  
        if (denominator == 0) {  
            throw new IllegalArgumentException("分母不能为 0");  
        }  
   
        this.numerator = numerator;  
        this.denominator = denominator;  
        shrink();  
    }  
   
    Fraction() {  
        this(0, 1);  
    }  
   
    public int getNumerator() {  
        return numerator;  
    }  
   
    public void setNumerator(int numerator) {  
        this.numerator = numerator;  
    }  
   
    public int getDenominator() {  
        return denominator;  
    }  
   
    public void setDenominator(int denominator) {  
        this.denominator = denominator;  
    }  
   
    // 分子分母同除以最大公约数  
    private Fraction shrink() {  
        int maxCommonDivisor = getMaxCommonDivisor(this.denominator, this.numerator);  
        this.numerator /= maxCommonDivisor;  
        this.denominator /= maxCommonDivisor;  
        return this;  
    }  
   
    // 辗转相除法求最大公约数  
    private int getMaxCommonDivisor(int a, int b) {  
        int mod = a % b;  
   
        if (mod == 0) {  
            return b;  
        } else {  
            return getMaxCommonDivisor(b, mod);  
        }  
    }  
   
    // 分数加法  
    public Fraction add(Fraction that) {  
        return new Fraction(this.numerator * that.denominator + this.denominator * that.numerator,  
                this.denominator * that.denominator);  
    }  
   
    // 分数减法  
    public Fraction minus(Fraction that) {  
        return new Fraction(this.numerator * that.denominator - this.denominator * that.numerator,  
               this.denominator * that.denominator);  
    }  
   
    // 分数乘法  
    public Fraction multiply(Fraction that) {  
        return new Fraction(this.numerator * that.numerator,  
                this.denominator * that.denominator);  
    }  
   
    // 分数除法  
    public Fraction devide(Fraction that) {  
        return new Fraction(this.numerator * that.denominator,  
                this.denominator * that.numerator);  
    }  
   
    public double doubleValue() {  
        return (double) numerator / denominator;  
    }  
   
    @Override 
    public String toString() {  
        return String.format("{%d/%d}", this.numerator, this.denominator);  
    }  
} 

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明