our task is to implement Tarjan's Algorithm to find the Strongly Connected Components (SCCs) of a directed graph and verify its functional correctness in Dafny. Preconditions: You can assume the graph contains at most 1,000 nodes. The graph is directed and represented as an adjacency list. Requirements: Implement the function find_sccs which returns a seq<seq<int>>. Output Format: The result must be a sequence of sequences, where each inner sequence represents one Strongly Connected Component. Partition: The set of returned components must form a partition of the graph vertices. Every node in the graph must appear in exactly one inner sequence. Single Nodes: A single node that is part of no cycle (or only a self-loop) is considered a valid SCC of size 1. Your output must include these "trivial" components. Strong Connectivity: For every component returned, and for every pair of nodes $(u, v)$ within that component, there must exist a path $u \rightsquigarrow v$ AND a path $v \rightsquigarrow u$. Maximality: The components must be maximal. This means no two components can be merged to form a larger strongly connected set. Formally, if there is a path from Component A to Component B, there must be no path from Component B back to Component A (The "Condensation Graph" must be a DAG). Verification Challenges: (1) DFS Invariants: Tarjan's algorithm uses discovery_time and low_link values. You must prove that low_link[u] correctly identifies the highest ancestor reachable from u in the DFS tree. (2) Stack Property: You must prove that the stack used during DFS correctly tracks the current path and potential "open" SCCs. Specifically, you must verify that popping from the stack when low_link[u] == discovery_time[u] yields exactly the nodes of the newly found SCC. (3) Maximality Proof: This is the most difficult step. You must prove that the algorithm does not "break" a large component into smaller valid pieces. The proof requires showing that the DFS search order ensures that by the time a root node is popped, all its descendants have been fully processed and assigned to their correct components.