CS 421: Programming Languages and Compilers
Machine Problem 3 (MP3)
MP3 will help you practice forward and tail recursion, higher-order functions and continution passing style. Keep in mind that your solution must define every required function, otherwise the grading program will not compile and you will receive no points for the entire homework set. For example, if you decide not to implement the function splat (for whatever reason), you need to have it defined as:
let splat x = raise (Failure(""))

IMPORTANT: Make sure that you read the README file in the grader bundle . This file contains important information.

Also, make sure you read the "Guide for Doing MPs".

Files
mp3.pdf (v1.1)
Corrects typo in type in description of problem 16
mp3grader.tar.gz (v1.1)
Corrects solution behavior on concat, concat2 when first element of input list is ""
mp3-sol.ml