Your task is to implement an algorithm to detect if a directed graph (unweighted) contains a cycle and verify its functional correctness in Verus. 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 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$. If using DFS, this typically involves proving that a "back-edge" points to a node currently in the recursion stack. (2) Completeness (Acyclicity): Proving that if the function returns false, no such cycle exists in the entire graph. This requires a strong invariant, such as proving that the graph nodes can be ordered (topologically) or that the recursion finished without finding any back-edges (3) Termination: Since the goal is to find a cycle (infinite loop in a naive traversal), you must prove the algorithm terminates even when cycles are present, typically by tracking a set of visited nodes.