有理数类设计

有理数类设计

一.有理数类代码

package com.company;

public class Rational {
   
    private int numerator;//分子
    private int denominator;//分母

    public int getNumerator() //获取分子
    {
   
        return numerator;
    }

    public int getDenominator()//获取分母
    {
   
        return denominator;
    }

    public Rational()//无参构造函数
    {
   
        this.numerator=0;
        this.denominator=1;
    }
    public Rational(int numerator,int denominator)//构造函数
    {
   
        int gcd=gcd(numerator,denominator);
        this.numerator=((denominator>0)?1:-1)*numerator/gcd;
        this.denominator=Math.abs(denominator)/gcd;
    }
    private static int gcd(int n,int d)//辗转相除法,求最大公约数
    {
   
        int n1=Math.abs(n);
        int n2=Math.abs(d);
        int tmp;
        while (n2 != 0) {
   
            tmp = n1 % n2;
            n1 = n2;
            n2 = tmp;
        }
        return n1;
    }
    public Rational add(Rational secondRational)//加法
    {
   
        int n=this.numerator*secondRational.getDenominator()+
                this.denominator*secondRational.getNumerator();
        int d=this.denominator*secondRational.getDenominator();
        return new Rational(n,d);
    }

    public Rational subtract(Rational secondRational)//减法
    {
   
        int n=this.numerator*secondRational.getDenominator()-
                this.denominator*secondRational.getNumerator();
        int d=this.denominator*secondRational.getDenominator();
        return new Rational(n,d);
    }

    public Rational multiply(Rational secondRational)//乘法
    {
   
        int n=this.numerator*secondRational.getNumerator();
        int d=this.denominator*secondRational.getDenominator();
        return new Rational(n,d);
    }

    public Rational divide(Rational secondRational)//除法
    {
   
        int n=this.numerator*secondRational.getDenominator();
        int d=this.denominator*secondRational.getNumerator();
        return new Rational(n,d);
    }

    public String toString()//转换为字符串类型
    {
   
        if (this.denominator==1)
        {
   
            return this.numerator+"";
        }else{
   
            return this.numerator+"/"+this.denominator;
        }
    }

    public boolean equals(Rational secondRational)//判断是否相等
    {
   
        if (this.subtract(secondRational).getNumerator()==0)
            return true;
        else
            return false;
    }

    public int compare(Rational secondRational)//比较大小
    {
   
        if (this.subtract(secondRational).getNumerator()>0)
            return 1;
        else if (this.subtract(secondRational).getNumerator()==0)
            return 0;
        else
            return -1;
    }

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

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

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

    public double doubleValue() //转换为double型
    {
   
        return this.numerator*1.0/this.denominator;
    }
}

二.测试代码

import com.company.Rational;

public class Main {
   

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

运行结果截图

有理数类设计

三.讨论

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

面向过程的C语言是对程序的执行过程的编写, 而面向对象编程是编写出很多功能性的代码,主要是对类的编写,在运用的时候很多时候只需要调用就可以了。

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

导入自己编写的有理数类

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

会依赖,不影响。

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

只需要调用就可以了。

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

导入自己编写的有理数类

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

会依赖,不影响。

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

合适,因为有的方法只能运用在类中,不能随便更改,需要通过public的方法访问该方法,保证数据的安全性。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114442.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python chr()和ord()_Python函数ord

    python chr()和ord()_Python函数ordord()函数主要用来返回对应字符的ascii码,chr()主要用来表示ascii码对应的字符他的输入时数字,可以用十进制,也可以用十六进制。例如:printord('a)#97pri

    2022年8月2日
    6
  • Oracle 19c之RPM安装「建议收藏」

    Oracle 19c之RPM安装「建议收藏」Oracle19c,或者说是Oracle12.2.0.3,是12c中稳定的版本,就像Oracle11.2.0.4,是值得让客户做出升级决策,从Oracle支持的版本…

    2022年6月9日
    79
  • 标志位简介

    标志位简介标志位简介:标志寄存器,又称程序状态寄存器(它的内容是ProgramStatusWord,PSW).这是一个存放条件码标志,控制标志和系统标志的寄存器.6个状态标志位CF—进位标志,加法时的最高位(D7或D15)产生进位或减法时最高位出现借位,则CF=1,否则CF=0;AF—辅助进位标志,供BCD码使用。当D3位出现进位或借位时AF=1,否则AF=0;

    2022年7月27日
    4
  • 详解 MNIST 数据集

    MNIST数据集已经是一个被”嚼烂”了的数据集,很多教程都会对它”下手”,几乎成为一个“典范”.不过有些人可能对它还不是很了解,下面来介绍一下.MNIST数据集可在http://yann.lecun.com/exdb/mnist/获取,它包含了四个部分:Trainingsetimages:train-images-idx3-ubyte.gz(9.9MB,解压后47

    2022年4月6日
    283
  • goland 2021 激活码【2021.8最新】

    (goland 2021 激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlS32PGH0SQB-eyJsaWNlbnNlSW…

    2022年3月26日
    80
  • linux(9)find命令详解「建议收藏」

    linux(9)find命令详解「建议收藏」find命令格式:findpath-option[-print][-exec-okcommand]{}\;find命令的参数:path:要查找的目录路径。~表示$HO

    2022年7月31日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号