Your task is to implement the Merge Sort algorithm and verify its correctness in Lean. Given a list of integers, return a new list containing the same elements sorted in non-decreasing order. Postconditions: (1) Output is sorted. (2) Output is a permutation of input. Preconditions: None. Implementation: Recursive divide-and-conquer. Split list into two halves, recursively sort them, then merge the sorted halves. Note: You should use 'partial' or a termination proof for recursion.
