The perfect matching problem is known to
be in P, in randomized NC, and it is hard for NL.
Whether the perfect matching problem is in NC is one of
the most prominent open questions in complexity
theory regarding parallel computations.
Grigoriev and Karpinski studied the perfect matching problem
for bipartite graphs with polynomially bounded permanent.
They showed that for such bipartite graphs
the problem of deciding the existence of a perfect matchings is in NC^2,
and counting and enumerating all perfect matchings is in NC^3.
In this paper
we extend and improve these results.
We show that for any graph that has a
polynomially bounded number of perfect matchings,
we can construct all perfect matchings in NC^2.
We extend the result to weighted graphs.