Your task is to implement the build operation for a Range Maximum Segment Tree and verify its correctness in Dafny . The operation constructs a valid, balanced segment tree for a given range $[l, r)$ where every position is initialized to 0, proceeding recursively: (1) Base Case: if the range represents a single element ($l + 1 == r$), create a leaf node containing the value 0; (2) Recursive Step: otherwise, calculate the midpoint, recursively build the left and right subtrees, and create a new internal node whose value is the maximum of its children's values. Specifically, you must prove (1) Functional Correctness: the resulting tree corresponds exactly to the requested range $[l, r)$ and represents an abstract view where every index $k$ in that range maps to 0, and (2) Invariant Establishment: the resulting data structure satisfies the is_segment_tree invariant, guaranteeing valid ranges, structural integrity, and the Max property at every node.