Implement a function lowest_common_ancestor that finds the lowest common ancestor of two nodes in a binary tree. Inputs: 1. root: A Tree representing the root of a binary tree. 2. p: An int value representing the first target node. 3. q: An int value representing the second target node. Assumptions & Constraints: 1. Existence: Both p and q are guaranteed to exist in the tree. 2. Uniqueness: All values in the tree are distinct; this ensures that p and q unambiguously identify specific unique nodes in the tree structure. Functional Specification (What to Return): The function must return a value lca_val such that: 1. Common Ancestor: The node containing lca_val is an ancestor of both p and q (a node is considered an ancestor of itself). 2. Lowest (Deepest): Among all common ancestors of p and q, the returned node is the one with the greatest depth (distance from the root). Verification Requirements: You must prove that the returned node satisfies the "Common Ancestor" property; you must prove that for all other nodes in the tree, if that node is a common ancestor, its depth is less than or equal to the depth of your returned node; and you must utilize the provided helper specifications (spec_get_depth, is_common_ancestor, tree_distinct) to construct your proof.
