Your task is to implement the 0/1 Knapsack algorithm and verify its correctness in Dafny. You are given a sequence of weights and a sequence of values for n items, and a maximum weight capacity W. The goal is to determine the maximum total value of items that can be included in the knapsack such that the total weight does not exceed W. Each item can be selected at most once (hence 0/1). In the incomplete code, the specification defines what constitutes a valid selection strategy (a sequence of booleans indicating whether each item is chosen) and how to calculate the total weight and value. Your task is to implement the algorithm (typically DP) and verify that it returns the optimal value. Specifically, you must prove: (1) Upper Bound: Any valid selection yields a total value less than or equal to the returned result. (2) Existence: There exists a valid selection whose total value is exactly equal to the returned result. Note that because Dafny integers are signed, explicit preconditions are added to ensure weights, values, and capacity are non-negative.