Java中一个分数类的简单设计

这个类对于分数提供化简和加减乘除四种操作,基于”不变”的设计原则,因此是线程安全的.

其中使用了几个算法:

[1]Fraction simpler(Fraction f);//分数化简

[2]Fraction[] RCD(Fraction f1, Fraction f2);//通分

[3]int GCD(int s, int b);//最大公约数

[4]int LCM(int a, int b);//最小公倍数

使用的形式:

[1]在控制台输入[分数][回车] //化简

[2]在控制台输入[分数][空格][运算符][空格][分数][回车] //计算

其中[运算符]为+ – * / 之一.

Fraction.java

package net.zj.fraction;import java.io.IOException;public class Fraction {   private int numeraTor;   private int denominaTor;   public Fraction(int numeraTor, int denominaTor) {    this.numeraTor = numeraTor;    this.denominaTor = denominaTor;   }   public Fraction(int numeraTor) {    this(numeraTor, 1);   }   public static Fraction add(Fraction f1, Fraction f2) {    Fraction[] fs = RCD(f1, f2);    Fraction add = new Fraction(fs[0].numeraTor + fs[1].numeraTor,     fs[0].denominaTor);    return simpler(add);   }   public static Fraction minus(Fraction f1, Fraction f2) {    Fraction[] fs = RCD(f1, f2);    Fraction minus = new Fraction(fs[0].numeraTor - fs[1].numeraTor,     fs[0].denominaTor);    return simpler(minus);   }   public static Fraction multi(Fraction f1, Fraction f2) {    Fraction multi = new Fraction(f1.numeraTor * f2.numeraTor,    f1.denominaTor * f2.denominaTor);    return simpler(multi);   }   public static Fraction div(Fraction f1, Fraction f2) {    return multi(f1, new Fraction(f2.denominaTor, f2.numeraTor));   }   public static void input(String s) {    String[] ss = s.split(" ");    if (ss.length == 1) {     Fraction f = StringToFraction(ss[0]);     if (f == null)      output("Usage: Should input a numeric");     else      output(f);    } else if (ss.length == 3) {     Fraction f1 = StringToFraction(ss[0]);     Fraction f2 = StringToFraction(ss[2]);     if (f1 == null) {      output("Usage: The first input should be numeric/numeric");      return;     }     if (f2 == null) {      output("Usage: The third input should be numeric/numeric");      return;     }     switch (ss[1].charAt(0)) {     case '+':      output(add(f1, f2));      break;     case '-':      output(minus(f1, f2));      break;     case '*':      output(multi(f1, f2));      break;      case '/':      output(div(f1, f2));      break;      default:      output("Usage: The second input should be one of +-*/");       break;     }    } else    output("Usage: Should input one fraction or two fractions and a operaTor with the style. 'f1 + f2'");   }   public static void output(Fraction f) {    if (f.denominaTor == 1) {     System.out.println(f.numeraTor);     return;    }    StringBuilder sb = new StringBuilder();    sb.append(f.numeraTor);    sb.append('/');    sb.append(f.denominaTor);    System.out.println(sb.toString());   }   public static void output(String s) {    System.out.println(s);   }   private static Fraction StringToFraction(String s) {    String[] ss = s.split("/");    try {     if (ss.length == 2)      return simpler(new Fraction(Integer.valueOf(ss[0]), Integer       .valueOf(ss[1])));     else if (ss.length == 1)      return new Fraction(Integer.valueOf(ss[0]));     else      return null;    } catch (NumberFormatException e) {      output("Usage: Should input one fraction or two fractions and a opera 发光并非太阳的专利,我也可以发光 。

Java中一个分数类的简单设计

相关文章:

你感兴趣的文章:

标签云: