Your task is to implement the "House Robber" algorithm (Dynamic Programming) and verify its correctness in Dafny. You are a professional robber planning to rob houses along a street. Each house has a certain amount of money stashed, the only constraint stopping you from robbing each of them is that adjacent houses have security systems connected and it will automatically contact the police if two adjacent houses were broken into on the same night. Given an integer array `nums` representing the amount of money of each house, return the maximum amount of money you can rob tonight without alerting the police. In the incomplete code, the specification defines what constitutes a valid robbery plan (a set of indices that are non-adjacent) and the total loot calculation. Your task is to implement the algorithm and prove: (1) Upper Bound: Any valid non-adjacent set of houses yields a total loot less than or equal to the returned result. (2) Existence: There exists a valid non-adjacent set whose total loot is exactly equal to the returned result.
