summaryrefslogtreecommitdiffstats
path: root/Scala/sandbox/3-rationals.scala
blob: 868f216f8e0fc597f65e30b6b1a7c770d454b371 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41

object Rationals {

  // primary constuctor
  class Rational(x :Int, y: Int) {
    require(y != 0, "denominator must be non zero") // throws IllegalArgumentException
    assert(y != 0)                                  // throws AssertionError

    // another constructor
    def this(x: Int) = this(x, 1)

    private def gcd(a: Int, b: Int): Int = if (b == 0) a else gcd(b, a % b)
    private val g = gcd(x, y)
    def numer = x / g
    def denom = y / g

    def neg = new Rational(-numer, denom)

    def less(that: Rational) = this.numer * that.denom < that.numer * this.denom

    def max(that: Rational) = if (this.less(that)) that else this

    def add(that: Rational) =
      new Rational(
        numer * that.denom + that.numer * denom,
        denom * that.denom)

    def sub(that: Rational) = add(that.neg)

    override def toString = numer + "/" + denom

  }

  def run = {
    println("Rationals")
    println(new Rational(2, 3).add(new Rational(3, 4)).toString)
    println(new Rational(1, 3).sub(new Rational(5 ,7)).sub(new Rational(3, 2)).toString)
    println(new Rational(1, 3).max(new Rational(5 ,7)).toString)
  }

}