algorithm graph_algorithm greedy_algorithm mst spanning_tree undirected_graph weighted_graph combinatorial_optimization