Your task is to implement an algorithm to detect if a directed graph (unweighted) contains a cycle and verify its functional correctness in Lean using Mathlib. You need to implement the function has_cycle, which returns true if the graph contains at least one cycle, and false if it is a Directed Acyclic Graph (DAG). The graph is represented as an Array of Array Nat (adjacency list). There are several verification challenges: (1) Soundness (Cycle Existence): Proving that if the function returns true, there indeed exists a path $p$ starting and ending at the same node with length $>1$. (2) Completeness (Acyclicity): Proving that if the function returns false, no such cycle exists in the entire graph. (3) Termination: Since the goal is to find a cycle, you must prove the algorithm terminates even when cycles are present, typically by tracking a set of visited nodes.
