Your task is to specify the K-th Smallest Element algorithm acting on a vector of integers and verify its correctness properties in Dafny. You need to implement a selection algorithm that rearranges elements to find the value that would occupy the $k$-th position if the array were fully sorted. Specifically, you must prove the following: (1) Data Integrity (Permutation): The final state of the mutable vector must be a valid permutation of its initial state, ensuring that the set of values remains identical and no elements are created or destroyed. (2) Correctness of Selection: The returned result must be proven to be the $k$-th smallest value of the original input; formally, this means there exists a theoretical sorted permutation of the input sequence where the value at index $k$ is exactly the returned result.