Your task is to implement Prim's Algorithm to find the Minimum Spanning Tree (MST) of a connected, undirected, weighted graph and verify its functional correctness in Dafny. The graph is represented as an adjacency list with int weights. Preconditions: You can assume the graph is connected (a path exists between any two nodes). You can assume the graph contains at most 100,000 nodes and edge weights are between -100,000 and 100,000 to prevent integer overflow. Crucially, the graph is a Simple Graph (no parallel edges between the same two nodes). Requirements: Implement the function prim_mst which returns a seq<(int, int, int)> (representing edges). (1) The returned sequence must contain exactly $N-1$ edges (where $N$ is the number of nodes). (2) The edges must form a valid Spanning Tree (connecting all nodes with no cycles). (3) Global Optimality: You must prove that the sum of weights of your returned edges is less than or equal to the sum of weights of any other possible spanning tree of the graph. Verification Challenges: (1)  The Cut Property: The core of Prim’s correctness. You must prove that adding the minimum weight edge connecting the "visited" set to the "unvisited" set is always safe (i.e., that edge belongs to some MST). (2) Tree Growth: Proving the invariant that at every step of the algorithm, the set of selected edges forms a single connected tree that is a subset of a valid MST. (3) Termination & Connectivity: Proving that the algorithm continues exactly until all vertices are included in the tree.