Programming Exercises in Recursion
- This is an individual assignment.
- You should complete the exercises in either Common Lisp (Breanndán's group) or Typed Racket (Lorenzo's group).
- Note that all of the numbers we will deal with in this assignment will be
counting numbers; not floats, complex or other numerical types. The counting
numbers are the non-negative integers, i.e. 0,1,2,3,...
- Call your repository recursion-exercises
- For each exercise, write a function of the given name.
- Provide tests for each function you write. Ensure good test coverage.
Lists
- sum-listfinds the sum of all numbers in the list.
- double-listreturn the list with elements which are double those of the input list.
- max-elementfinds the largest number in the list.
- positivesreturns a list of the elements of the input list which are positive numbers (in the same order as they appear in the input list).
- merge-listtakes two lists of numbers, both sorted in ascending order. It produces a single sorted list of numbers that contains all the numbers on both inputs lists. A number occurs in the output as many times as it occurs on the two input lists together.
The counting numbers
- copies-xtakes a counting number,- n, and return a list containing- ncopies of the symbol- x.
- copiesgeneralises- copies-xto a function that can produce a given number of any symbol desired.
- square-fromreturns a list of squares of a given length starting from a given counting number.- (squares 8 4) ; => (64 81 100 121) 
- taketakes a list and a counting number,- nand returns the list consisting of the first- nelements of the input list.
- droptakes a list and a counting number,- nand returns the list gotten by dropping the first- nelements of the input list.
Binary Trees
In Lisp we define a binary tree as:
(deftype bt () '(or node null)) (defstruct node (value nil :type fixnum) (left nil :type bt) (right nil :type bt))
In Typed Racket we define a binary tree as:
(define-type BT (U Node Null)) (struct node ((value : Integer) (left : BT) (right : BT)) #:type-name Node #:transparent)
Note the distinction between a binary tree (BT) and a binary search tree (BST). The latter has the extra property that the number at any node is greater than the numbers at all nodes left of it and less than the numbers at all nodes right of it.
A path is a list containing only the symbols left and right e.g.
'(left left right left)
In Common Lisp, the false value is nil. In Typed Racket the false value is
#false.
- bst<-listtakes a list of integers and returns a BST containing those integers.
- bt-member?takes a number and a BT and determines whether the number is present in the BT.
- bst-member?takes a number and a BST and determines whether the number is present in the BST.
- bst-pathtakes a number and a BST and returns a path describing the route from the root of the BST to the number if the number is present in the BST, or the false value if it is not.
- bt-pathtakes a number and a BT and returns a path describing the route from the root of the BT to the number if the number is present in the BT, or the false value if it is not.
- bt-follow-pathtakes a path and a BT and returns the number found by following the path through the BT, or the false value in case the path is not present in the BT.
- Design three functions which takes a BT and returns a list of the numbers
occurring in the BT
- bt-traverse-left-to-rightfrom left to right
- bt-traverse-depth-firstin depth-first search order
- bt-traverse-breadth-firstin breadth-first search order
 
- path-sumtakes a BT and a number and returns a path in the BT whose elements sum to that number or the false value if there is no such path.
- path-max-sumtakes a BT and returns the path through the BT that has the greates path sum among all of its paths.
- bt-symmetric?determines whether a BT is symmetric around its vertical axis.
- reverse-bsttakes a BST and returns the BST with the same elements but in decreasing order left to right, instead of increasing order. The output BST should be a mirror image of the input BST reflected through a vertical line.
S-expressions
In Common Lisp we define an s-expression to be anything which satisfies atom
or consp.
In Typed Racket we define an s-expression as:
(define-type Atom (U Integer String Symbol)) (define-type S-Expression (U Atom (Listof S-Expression)))
- sexp-stringstakes an s-expression and returns a list of all of the strings it contains.
- sexp-sum-numberstakes an s-expression and returns the sum of all the numbers occurring in it.
- sexp-simplify-arithmetictakes an s-expression and simplifies any arithmetic expression occurring in it. For example in this s-expression,- (a b (+ 3 4) c d (* 5 6 e)) - the subexpression - (+ 3 4)is arithmetic, while the subexpression- (* 5 6 e)is not.