Your task is to implement the Longest Increasing Subsequence (LIS) algorithm and verify its correctness in Lean. Given a sequence of integers, find the length of the longest subsequence where the elements are strictly increasing. Postconditions: Upper Bound (result ≥ length of any valid strictly increasing subsequence) and Existence (result = length of some valid strictly increasing subsequence). A valid subsequence is defined by a strictly increasing sequence of indices pointing to strictly increasing values.
