Your task is to implement the Quick 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. Pick a pivot (e.g., head), partition the remaining elements into those less-than-or-equal and those greater-than, then recursively sort and append. Use 'partial' or prove termination (decreasing size).
