Your task is to implement the Search operation for a Ternary Search Tree (TST) and verify its correctness in Lean. A TST Node has a value (val), an end marker (is_end), and three children: left (val > char), mid (val == char), right (val < char). Postconditions: Functional Correctness (view(result) = view(tree) contains key). Preconditions: Input assumed well-formed. Search logic respects 3-way branching.
