maximum cardinality matching by Edmonds' algorithm, an implementation based on union find data structure