You task is to implement the algorithm for longest increasing subsequence problem and verify its correctness in Dafny. For simplicity, the sequence only contains integer, and we only consider strictly increasing subsequence. The algorithm only needs to return the length of the longest increasing subsequence. In the incomplete code, it contains the definition of a valid increasing subsequence. You task is to implement the longest increasing subsequence algorithm and verify that the code indeed returns the length of the longest increasing subsequence, i.e, any increasing subsequence has length at most the return of the algorithm, and there exists an increasing subsequence that has the length equal to the returned value.
