java黑皮书课后习题13.19将十进制转化为分数

package Test;

import java.math.BigInteger;
import java.util.Scanner;

public class Rational extends Number implements Comparable{

//private long[] r = new long[2];
/*private long numerator = 0;
private long denominator = 1;*/
private BigInteger numberator = new BigInteger("0");
private BigInteger denominator = new BigInteger("1");


public Rational() {
	this(0,1);
}

public Rational(long numerator,long denominator) {
	long gcd = gcd(numerator,denominator);
	this.numberator = BigInteger.valueOf(((denominator > 0)? 1 : -1) * numerator / gcd);
	this.denominator = BigInteger.valueOf(Math.abs(denominator) / gcd);
}

public static long gcd(long numerator,long denominator) {
	long gcd = 1;
	for(long i = 1;i <= Math.abs(numerator) && i <= denominator;i++) {
		if(numerator % i == 0 && denominator % i == 0) {
			gcd = i;
		}
	}
	return gcd;
}

public long getNumerator() {
	return numberator.longValue();
}

public long getDenominator() {
	return denominator.longValue();
}

public Rational add(Rational secondRational) {
	long n = numberator.longValue() * secondRational.getDenominator()
			+ denominator.longValue() * secondRational.getNumerator();
	long m = denominator.longValue() * secondRational.getDenominator();
	return new Rational(n,m);
}

public Rational subtract(Rational secondRational) {
	long n = numberator.longValue() * secondRational.getDenominator()
			- denominator.longValue() * secondRational.getNumerator();
	long m = denominator.longValue() * secondRational.getDenominator();
	return new Rational(n,m);
}

public Rational multiply(Rational secondRational) {
	long n = numberator.longValue() * secondRational.getNumerator();
	long m = denominator.longValue() * secondRational.getDenominator();
	return new Rational(n,m);
}

public Rational divide(Rational secondRational) {
	long n = numberator.longValue() * secondRational.getDenominator();
	long m = denominator.longValue() * secondRational.getNumerator();
	return new Rational(n,m);
}

@Override
public String toString() {
	if(denominator.longValue() == 1)
		return numberator.longValue() + "";
	else
		return numberator.longValue() + "/" + denominator.longValue();
}

@Override
public boolean equals(Object object) {
	return (this.subtract((Rational)(object)).getNumerator()) == 0 ? true : false;
}

@Override
public int intValue() {
	return (int)doubleValue();
}

@Override
public float floatValue() {
	return (float)doubleValue();
}

@Override
public double doubleValue() {
	return numberator.longValue() * 1.0 / denominator.longValue();
}

@Override
public long longValue() {
	return (long)doubleValue();
}

@Override
public int compareTo(Rational o) {
	if(this.subtract(o).getNumerator() > 0)
		return 1;
	else if(this.subtract(o).getNumerator() < 0)
		return -1;
	else
		return 0;
}

public static void main(String[] args) {
	Scanner input = new Scanner(System.in);
	System.out.print("Enter a decimal number: ");
	String num = input.next();
	String[] nums = num.split("\\.");
	Rational num1 = new Rational(Long.parseLong(nums[0]),1);
	Rational result;
	if(nums.length == 2) {
		Rational num2 = new Rational((long)(num.charAt(0) == '-' ? -1 : 1) * Long.parseLong(nums[1]),(long)Math.pow(10, nums[1].length()));
		result = num1.add(num2);
	}else {
		result = num1;
	}
	System.out.println("The fraction number is " + result.getNumerator() + "/" + result.getDenominator());
	
}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值