当前位置: 代码迷 >> 综合 >> PAT1-有理数类(代码填空题)
  详细解决方案

PAT1-有理数类(代码填空题)

热度:33   发布时间:2023-11-17 23:05:45.0

有理数类

有理数就是可以表示为两个整数的比值的数字。一般情况下,我们用近似的小数表示。但有些时候,不允许出现误差,必须用两个整数来表示一个有理数。这时,我们可以建立一个“有理数类”,下面的代码初步实现了这个目标。为了简明,它只提供了加法和乘法运算。

public class Rational{private long ra;//分子private long rb;//分母private long gcd(long a, long b){if(b==0) return a;return gcd(b,a%b);//递归求最大公因数,直到b为0时,a才为最大公因数 }public Rational(long a, long b){//求分数的最简形式ra = a;rb = b;	long k = gcd(ra,rb);if(k>1){ //需要约分ra /= k;  rb /= k;}}// 加法public Rational add(Rational x){return new Rational((ra*x.rb+rb*x.ra),rb*x.rb) ;//填空位置}// 乘法public Rational mul(Rational x){return new Rational(ra*x.ra, rb*x.rb);}public String toString(){if(rb==1) return "" + ra;return ra + "/" + rb;}public static void main(String[] args) {Rational a = new Rational(1,3);Rational b = new Rational(1,6);Rational c = a.add(b);System.out.println(a + "+" + b + "=" + c);}}