[Haskell-cafe] Clarification Please

Michael Vanier mvanier at cs.caltech.edu
Thu Sep 13 23:02:45 EDT 2007


Define a merge function that merges two sorted lists into a sorted list containing all the elements 
of the two lists.  Then define the msort function, which will be recursive.

Mike

PR Stanley wrote:
> Hi
> Taken from chapter 6, section 8 of the Hutton book on programming in 
> Haskell:
> 5. Using merge, define a recursive function
> msort :: (Ord a) => [a] -> [a]
> that implements merge sort, in which the empty list and singleton lists 
> are already sorted, and any other list is sorted by merging together the 
> two lists that result from sorting the two halves of the list separately. :
> Hint: first define a function
> ¬halve :: [a] -> [([a], [a])]
> ¬that splits a list into two halves whose length differs by at most one.
> 
>     Create a halve function - okay, that's fairly straightforward. The 
> rest, I'm afraid, is a little obscure. I'm not looking for the solution; 
> I'd like to work that out for meself. However, I'd  really appreciate 
> some clues as to the general structure of the algorithm.
> Much obliged,
> Paul
> 
> _______________________________________________
> Haskell-Cafe mailing list
> Haskell-Cafe at haskell.org
> http://www.haskell.org/mailman/listinfo/haskell-cafe


More information about the Haskell-Cafe mailing list