added assignment 2 ex 1
This commit is contained in:
parent
8639e2854a
commit
17b5c3adeb
@ -15,4 +15,4 @@ def sqrt(x: Double, approx: Double): Double = if (
|
|||||||
sqrt(x, improve(x, approx))
|
sqrt(x, improve(x, approx))
|
||||||
}
|
}
|
||||||
|
|
||||||
sqrt(612, 10)
|
sqrt(612, 10)
|
||||||
|
17
src/Assignment2/Ex1.sc
Normal file
17
src/Assignment2/Ex1.sc
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import scala.annotation.tailrec
|
||||||
|
|
||||||
|
def fib(x: Int): Int = if (x == 0 || x == 1) {x} else {
|
||||||
|
fib(x - 1) + fib(x - 2)
|
||||||
|
}
|
||||||
|
|
||||||
|
def fibTail(x: Int): Int = {
|
||||||
|
@tailrec
|
||||||
|
def fibTailStep(x: Int, a: Int, b: Int): Int = {
|
||||||
|
if (x == 0) {a}
|
||||||
|
else fibTailStep(x - 1, b, a + b)
|
||||||
|
}
|
||||||
|
fibTailStep(x, 0, 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
fib(10)
|
||||||
|
fibTail(10)
|
Loading…
x
Reference in New Issue
Block a user