scala基础编程案例--定义一个类Rational支持有理数的运算


1、案例要求

1)定义一个类Rational,分子与分母作为类参数;
2)重写toString方法;
3)前提条件检查(分母是否为0检查);
4)定义add方法实现两个有理数相加;
5)为 Rational 定义一个辅助构造函数,当分母为1时调用该辅助构造函数;
6)定义一个求分子分母最大公约数的方法,用于有理数的简化。

2、实现思路

1)定义一个类Rational,分子与分母作为类参数;

//有理数类
  class Rational(n: Int, d: Int) {}

2)重写toString方法;

//重写打印函数
    override def toString: String = {
      if (denominator != 1) numerator + "/" + denominator
      else numerator+""
    }

3)前提条件检查(分母是否为0检查);

//分母要求不能为0
    require(d != 0)

4)定义add方法实现两个有理数相加;

//实现分数加法函数
    def add(that: Rational): Rational = {
      new Rational(numerator * that.denominator + denominator * that.numerator,
        denominator * that.denominator)
    }

5)为 Rational 定义一个辅助构造函数,当分母为1时调用该辅助构造函数;

//辅助构造函数:若只传入一个参数,则构建n/1
    def this(n:Int) = this(n, 1)

6)定义一个求分子分母最大公约数的方法,用于有理数的简化。

	//求最大公约数
    private val g = gcd(n.abs, d.abs)

    //求最大公约数函数
    private def gcd(a: Int, b : Int) : Int =
      if (b == 0) a else gcd(b, a % b)
      
    //化简后的分子
    def numerator: Int = n/g

    //化简后的分母
    def denominator: Int = d/g
  

3、完整代码

object demo1 {
  //有理数类
  class Rational(n: Int, d: Int) {
    //分母要求不能为0
    require(d != 0)

    //辅助构造函数:若只传入一个参数,则构建n/1
    def this(n:Int) = this(n, 1)

    //化简后的分子
    def numerator: Int = n/g

    //化简后的分母
    def denominator: Int = d/g

    //重写打印函数
    override def toString: String = {
      if (denominator != 1) numerator + "/" + denominator
      else numerator+""
    }

    //实现分数加法函数
    def add(that: Rational): Rational = {
      new Rational(numerator * that.denominator + denominator * that.numerator,
        denominator * that.denominator)
    }

    //求最大公约数
    private val g = gcd(n.abs, d.abs)

    //求最大公约数函数
    private def gcd(a: Int, b : Int) : Int =
      if (b == 0) a else gcd(b, a % b)
  }

  //主函数
  def main(args: Array[String]): Unit = {
  	//测试
    var r = new Rational(1, 2)
    var r1 = new Rational(3, 6)
    println(r.add(r1))
    var r2 = new Rational(3, 6)
    println(r2)
  }

}

4、总结

scala编程总体上还是与java十分相似,但代码风格更加简洁高效,大家如果有余力的话,可以尝试实现该有理数类的减法、乘法、除法等运算!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
有理数)创建一个名为 Rational,用于对分数进行算术运算。编写一个程序来测试你的。使用整数变量来表示的私有实例变量——分子分母。 提供一个构造函数,使该的对象能够在声明时进行初始化。构造函数应以简化形式存储分数。分数 2/4 等价于 1/2,并将作为分子中的 1 和分母中的 2 存储在对象中。 如果没有提供初始值设定项,请提供默认值为 1 的无参数构造函数。 提供执行以下每个操作的公共方法: a) 将两个有理数相加:相加的结果应以简化形式存储。 b) 两个有理数相减:相减的结果应以简化形式存储。 c) 将两个有理数相乘:相乘的结果应以简化形式存储。 d) 将两个有理数相除:相除的结果应以简化形式存储。 e) 以 a/b 的形式返回有理数的字符串表示形式,其中 a 是分子,b 是分母。 f) 以浮点格式返回有理数的字符串表示形式. (考虑提供格式化功能,的用户能够指定小数点右侧的精度位数。) 【Sample output 1】 Enter numerator 1: 12 Enter denominator 1: 3 Enter numerator 2: 5 Enter denominator 2: 14 Enter precision: 3 a=4/1 b=5/14 a + b = 61/14 = 4.357 a - b = 51/14 = 3.643 a * b = 10/7 = 1.429 a / b = 56/5 = 11.200 【Sample output 2】 Enter numerator 1: 1 Enter denominator 1: 4 Enter numerator 2: 75 Enter denominator 2: 35 Enter precision: 1 a=1/4 b=15/7 a + b = 67/28 = 2.4 a - b = -53/28 = -1.9 a * b = 15/28 = 0.5 a / b = 7/60 = 0.1 Note: The red texts are inputed ,others are output texts. Just use a space to seperate words

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值