Your task is to implement the Bubble Sort algorithm and verify its correctness in Lean. Given a list of integers, return a new list containing the same elements but in non-decreasing order. Postconditions: (1) The output list is sorted. (2) The output list is a permutation of the input list. Preconditions: None (valid for any list which fits in memory). Implementation should use the standard O(N^2) bubble sort logic: repeatedly iterate through the list, swapping adjacent elements if they are in the wrong order, until no swaps are needed.
