20 December 2014

Exercise 1: Pascal’s Triangle

The following pattern of numbers is called Pascal’s triangle.

    1
   1 1
  1 2 1
 1 3 3 1
1 4 6 4 1
   ...

The numbers at the edge of the triangle are all 1, and each number inside the triangle is the sum of the two numbers above it. Write a function that computes the elements of Pascal’s triangle by means of a recursive process.

Do this exercise by implementing the pascal function in Main.scala, which takes a column c and a row r, counting from 0 and returns the number at that spot in the triangle. For example, pascal(0,2)=1, pascal(1,2)=2 and pascal(1,3)=3.

def pascal(c: Int, r: Int): Int

 

[code lang="Scala"]
def pascal (c:Int,r:Int):Int={
def pascal_dp=List()

def pascalTailCur(c:Int,r:Int,dp:List[Int], r_calculating:Int): Int={
if(r<r_calculating) dp.apply((r+1)*r/2+c)
else pascalTailCur(c,r,listizePascalTriangleRowCur(r_calculating,dp,0),r_calculating+1)
}

def listizePascalTriangleRowCur(r_calculating:Int, dp:List[Int],r:Int):List[Int]={
if (r==r_calculating) dp:::List(1)
else if (r==0) listizePascalTriangleRowCur(r_calculating, dp:::List(1),r+1)
else listizePascalTriangleRowCur(r_calculating, dp:::List(dp(dp.length-r_calculating)+dp(dp.length-r_calculating-1)),r+1)
}

pascalTailCur(c,r,pascal_dp,0)
}
[/code]

 

 

Exercise 2: Parentheses Balancing

Write a recursive function which verifies the balancing of parentheses in a string, which we represent as a List[Char] not a String. For example, the function should return true for the following strings:

  • (if (zero? x) max (/ 1 x))
  • I told him (that it’s not (yet) done). (But he wasn’t listening)

The function should return false for the following strings:

  • :-)
  • ())(

The last example shows that it’s not enough to verify that a string contains the same number of opening and closing parentheses.

Do this exercise by implementing the balance function in Main.scala. Its signature is as follows:

def balance(chars: List[Char]): Boolean

There are three methods on List[Char] that are useful for this exercise:

  • chars.isEmpty: Boolean returns whether a list is empty
  • chars.head: Char returns the first element of the list
  • chars.tail: List[Char] returns the list without the first element

Hint: you can define an inner function if you need to pass extra parameters to your function.

Testing: You can use the toList method to convert from a String to a List[Char]: e.g. "(just an) example".toList.

 

 

[code lang="Scala"]
def balance(chars: List[Char]): Boolean = {
def balanceCur(chars:List[Char], sum:Int): Boolean={
if(sum<0) false
else if (sum==0 && chars.isEmpty) true
else if (sum!=0 && chars.isEmpty) false
else {
if (chars.head=='(') balanceCur(chars.tail,sum+1)
else if (chars.head==')') balanceCur(chars.tail,sum-1)
else balanceCur(chars.tail,sum)
}
}
balanceCur(chars,0);
}
[/code]

 

 

Exercise 3: Counting Change

Write a recursive function that counts how many different ways you can make change for an amount, given a list of coin denominations. For example, there are 3 ways to give change for 4 if you have coins with denomiation 1 and 2: 1+1+1+1, 1+1+2, 2+2.

Do this exercise by implementing the countChange function in Main.scala. This function takes an amount to change, and a list of unique denominations for the coins. Its signature is as follows:

def countChange(money: Int, coins: List[Int]): Int

Once again, you can make use of functions isEmpty, head and tail on the list of integers coins.

Hint: Think of the degenerate cases. How many ways can you give change for 0 CHF? How many ways can you give change for >0 CHF, if you have no coins?

 

 

[code lang="Scala"]
def countChange(money: Int, coins: List[Int]): Int ={
def countChangeCur (money:Int, coins:List[Int], sum:Int) : Int={
if (coins.isEmpty) sum
else if (money ==0) 1+sum
else if (coins.length==1 && money % coins.head==0) 1+sum
else if (coins.head>money) countChangeCur(money, coins.tail, sum)
else {
countChangeCur (money,coins.tail,sum+countChangeCur(money-coins.head,coins,0))
}
}
countChangeCur(money,coins,0)
}
[/code]



blog comments powered by Disqus