function [Pi_hat] = onestepsolver(X, Y)

B_hat = X'*Y; 
for curidx = 1:size(Y,2)
    [~, b_hat_idx] = sort(abs(B_hat(:, curidx)), 'descend'); 
    B_hat(b_hat_idx(2:end), curidx) = 0;
end
pi_in = Y*B_hat'*X';
Pi_hat = sparseAssignmentProblemAuctionAlgorithm(sparse(pi_in - min(pi_in(:))));