Your task is to implement the Quick Select algorithm to find the k-th smallest element and verify its correctness in Lean. Given a list of integers and an index k, return the k-th smallest element (0-indexed). Postconditions: The result is the element that would be at index k if the array were sorted. Preconditions: k < array.size. Implementation: Recursive partition-based selection (like Quick Sort partition). Return the element if the pivot index is k, otherwise recurse into the appropriate sub-array. Time complexity should be O(N) on average.
