Your task is to implement the Jump Game algorithm (Greedy/DP) and verify its correctness in Dafny. You are given an integer array `nums`. You are initially positioned at the array's first index. Each element `nums[i]` represents your maximum jump length at that position. Return `true` if you can reach the last index, or `false` otherwise. In the incomplete code, the specification defines what constitutes a valid path of jumps from start to end. Your task is to implement the algorithm (typically greedy: maintaining the max reachable index) and verify that it correctly determines reachability. Specifically, prove: (1) Soundness: If returns true, there exists a valid sequence of jumps to the last index. (2) Completeness: If returns false, no such sequence exists.
