有理数类的定义

一、代码预览

public class Rational {
	private int num = 0;
	private int deno = 1;

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

	public Rational(int num, int deno) // 约分到最简
	{
		int gcd = gcd(num, deno);
		this.num = (deno > 0 ? 1 : -1) * num / gcd;
		this.deno = Math.abs(deno) / gcd;
	}

	public static int gcd(int n, int d)// 寻找最大公约数
	{
		int nl = Math.abs(n);
		int dl = Math.abs(d);
		int gcd = 1;
		int min = nl;
		if (nl > dl) {
			min = dl;
		}
		for (int i = 1; i <= min; i++) {
			if (nl % i == 0 && dl % i == 0) {
				gcd = i;
			}
		}
		return gcd;
	}

	public int getNum() // 获得分子
	{
		return num;
	}

	public int getDeno() // 获得分母
	{
		return deno;
	}

	public Rational add(Rational second)// 加法运算
	{
		int n = num * second.getDeno() + deno * second.getNum();
		int d = deno * second.getDeno();
		return new Rational(n, d);
	}

	public Rational minus(Rational second)// 减法运算
	{
		int n = num * second.getDeno() - deno * second.getNum();
		int d = deno * second.getDeno();
		return new Rational(n, d);
	}

	public Rational multiply(Rational second)// 乘法运算
	{
		int n = num * second.getNum();
		int d = deno * second.getDeno();
		return new Rational(n, d);
	}

	public Rational divide(Rational second)// 除法运算
	{
		int n = num * second.getDeno();
		int d = deno * second.getNum();
		return new Rational(n, d);
	}

	public int intValue() // 转换为int类型
	{
		return (int) doubleValue();
	}

	public float floatValue() // 转换为float类型
	{
		return (float) doubleValue();
	}

	public double doubleValue() // 转换为double类型
	{
		return num * 1.0 / deno;
	}

	public long longValue() // 转换为long类型
	{
		return (long) doubleValue();
	}

	public String toString()// 转换为string类型
	{
		if (deno == 1) {
			return num + "";
		} else {
			return num + "/" + deno;
		}
	}

	public void compare(Rational second) // 比较两个有理数
	{
		Rational x = minus(second);
		if (x.getNum() > 0) {
			System.out.println(num + "/" + deno + "大于" + second.getNum() + "/" + second.getDeno());
		} else if (x.getNum() == 0) {
			System.out.println(num + "/" + deno + "等于" + second.getNum() + "/" + second.getDeno());
		} else {
			System.out.println(num + "/" + deno + "小于" + second.getNum() + "/" + second.getDeno());
		}
	}
	
}

二、测试代码

public static void main(String[] args) {
    Rational x = new Rational(1, 3);
    Rational y = new Rational(4, 6);
    System.out.println(x.add(y));
    System.out.println(x.minus(y));
    System.out.println(x.multiply(y));
    System.out.println(x.divide(y));
    System.out.println(x.intValue());
    System.out.println(x.floatValue());
    System.out.println(x.doubleValue());
    System.out.println(x.longValue());
    System.out.println(x.toString());
    x.compare(y);
}

三、运行结果

四、讨论

1.尝试描述怎么与c语言的有理数代码相比较,为什么你设计的类更加面向对象?

c语言中这些运算是通过函数来实现的。而设计的类会具象化,有属性和方法,这些都是比较直观的。

2.别人如何复用你的代码?

导入我写的有理数类方可使用。

3.别人的代码是否依赖你的有理数类的属性?当你的有理数类的属性修改时,是否会影响他人调用你有理数类的代码?

是,因为他调用了我的有理数类,也就调用了其中的属性。不会影响,属性设置为private型。

4.有理数类的public方法是否设置合适?为什么有的方法设置为private?

当你不希望你的方法可以被别人使用时可以使用private来设置方法,其具有一定的保护作用。而public就是公共的意思,方便调用。

posted on 2020-10-04 00:48  望眼欲穿。  阅读(357)  评论(0编辑  收藏  举报