algorithm graph_algorithm graph_theory spanning_tree tree weighted_graph undirected_graph combinatorial_optimization optimization_problem subgraph