Matchings with Lower Quotas: Algorithms and Complexity
 1.6k Downloads
 2 Citations
Abstract
We study a natural generalization of the maximum weight manytoone matching problem. We are given an undirected bipartite graph \(G= (A\, \dot{\cup }\, P, E)\) with weights on the edges in E, and with lower and upper quotas on the vertices in P. We seek a maximum weight manytoone matching satisfying two sets of constraints: vertices in A are incident to at most one matching edge, while vertices in P are either unmatched or they are incident to a number of matching edges between their lower and upper quota. This problem, which we call maximum weight manytoone matching with lower and upper quotas (WMLQ), has applications to the assignment of students to projects within university courses, where there are constraints on the minimum and maximum numbers of students that must be assigned to each project. In this paper, we provide a comprehensive analysis of the complexity of WMLQ from the viewpoints of classical polynomial time algorithms, fixedparameter tractability, as well as approximability. We draw the line between \(\textsf {NP}\)hard and polynomially tractable instances in terms of degree and quota constraints and provide efficient algorithms to solve the tractable ones. We further show that the problem can be solved in polynomial time for instances with bounded treewidth; however, the corresponding runtime is exponential in the treewidth with the maximum upper quota \(u_{\max }\) as basis, and we prove that this dependence is necessary unless \(\textsf {FPT}= \textsf {W}[1]\). The approximability of WMLQ is also discussed: we present an approximation algorithm for the general case with performance guarantee \(u_{\max }+1\), which is asymptotically best possible unless \(\textsf {P}= \textsf {NP}\). Finally, we elaborate on how most of our positive results carry over to matchings in arbitrary graphs with lower quotas.
Keywords
Maximum matching Manytoone matching Project allocation Inapproximability Bounded treewidth1 Introduction
Many university courses involve some element of teambased project work. A set of projects is available for a course and each student submits a subset of projects as acceptable. For each acceptable student–project pair (s, p), there is a weight w(s, p) denoting the utility of assigning s to p. The question of whether a given project can run is often contingent on the number of students assigned to it. Such quota constraints also arise in various other contexts involving the centralized formation of groups, including organizing teambased activities at a leisure center, opening facilities to serve a community and coordinating rides within carsharing systems. In these and similar applications, the goal is to maximize the utility of the assigned agents under the assumption that the number of participants for each open activity is within the activity’s prescribed limits.
We model this problem using a weighted bipartite graph \(G= (A\,\dot{\cup }\,P, E)\), where the vertices in A represent applicants, while the vertices in P are posts they are applying to. So in the above student–project allocation example, A and P represent the students and projects respectively, and E represents the set of acceptable student–project pairs. The edge weights capture the cardinal utilities of an assigned applicant–post pair. Each post has a lower and an upper quota on the number of applicants to be assigned to it, while each applicant can be assigned to at most one post. In a feasible assignment, a post is either open or closed: the number of applicants assigned to an open post must lie between its lower and upper quota, whilst a closed post has no assigned applicant. The objective is to find a maximum weight manytoone matching satisfying all lower and upper quotas. We denote this problem by WMLQ.
In this paper, we study the computational complexity of WMLQ from various perspectives. We begin by defining the problem formally in Sect. 2. Then in Sect. 3, we show that WMLQ can be solved efficiently if the degree of every post is at most 2, whereas the problem becomes hard as soon as posts with degree 3 are permitted, even when lower and upper quotas are all equal to the degree, and every applicant has a degree of 2. Furthermore, we show the tractability of the case of pair projects, i.e., when all upper quotas are at most 2. In Sect. 4, we study the fixed parameter tractability of WMLQ. To this end, we generalize the known dynamic program for maximum independent set with bounded treewidth to WMLQ. The running time of our algorithm is exponential in the treewidth of the graph, with \(u_{\max }\), the maximum upper quota of any vertex, as the basis. This yields a fixedparameter algorithm when parameterized by both the treewidth and \(u_{\max }\). We show that this exponential dependence on the treewidth cannot be completely separated from the remaining input by establishing a W[1]hardness result for WMLQ parameterized by treewidth. Finally, in Sect. 5, we discuss the approximability of the problem. We show that a simple greedy algorithm yields an approximation guarantee of \(u_{\max }+1\) for WMLQ and \(\sqrt{A}+1\) in the case of unit edge weights. We complement these results by showing that these approximation factors are asymptotically best possible, unless \(\textsf {P}= \textsf {NP}\). We briefly comment on the generalizability our aforementioned results in Sect. 6 for matchings in arbitrary graphs with lower quotas.
1.1 Related Work
Among various applications of centralized group formation, perhaps the assignment of medical students to hospitals has received the most attention. In this context, as well as others, the underlying model is a bipartite matching problem involving lower and upper quotas. The Hospitals/Residents problem with Lower Quotas (HRLQ) [4, 14] is a variant of WMLQ where applicants and posts have ordinal preferences over one another, and we seek a stable matching of residents to hospitals. Hamada et al. [14] considered a version of HRLQ where hospitals cannot be closed, whereas the model of Biró et al. [4] permitted hospital closures. Strategyproof mechanisms have also been studied in instances with ordinal preferences and no hospital closures [9, 12, 13].
The Student/Project Allocation problem [24, Section 5.6] models the assignment of students to projects offered by lecturers subject to upper and lower quota restrictions on projects and lecturers. Several previous papers have considered the case of ordinal preferences involving students and lecturers [1, 16, 25] but without allowing lower quotas. However two recent papers [18, 26] do permit lower quotas together with project closures, both in the absence of lecturer preferences. Monte and Tumennasan [26] considered the case where each student finds every project acceptable, and showed how to modify the classical “serial dictatorship” mechanism to find a Pareto optimal matching. Kamiyama [18] generalized this mechanism to the case where students need not find all projects acceptable, and where there may be additional restrictions on the sets of students that can be matched to certain projects. This paper also permits lower quotas and project closures, but our focus is on cardinal utilities rather than ordinal preferences. Cardinal utilities can facilitate a more flexible representation of preferences and they occur naturally in various matching problems, such as the solution of symmetric indefinite systems [31], the organization of Chess tournaments [28] or car sharing [15]. Moreover, various methods for converting ordinal preferences into cardinal utilities are known, such as the normalized Borda score [30].
The unitweight version of WMLQ is also closely related to the Dmatching problem [8, 23, 33], a variant of graph factor problems [29]. In an instance of the Dmatching problem, we are given a graph G, and a domain of integers is assigned to each vertex. The goal is to find a subgraph \(G'\) of G such that every vertex has a degree in \(G'\) that is contained in its domain. Lovász [22] showed that the problem of deciding whether such a subgraph exists is \(\textsf {NP}\)complete, even if each domain is either \(\{1\}\) or \(\{0,3\}\). On the other hand, some cases are tractable. For example, if for each domain D, the complement of D contains no consecutive integers, the problem is polynomially solvable [33]. As observed in [32], Dmatchings are closely related to extended global cardinality constraints and the authors provided an analysis of the fixedparameter tractability of a special case of the Dmatching problem; see Sect. 4 for details.
The problem that we study in this paper corresponds to an optimization version of the Dmatching problem. We consider the special case where G is bipartite and the domain of each applicant vertex is \(\{0,1\}\), whilst the domain of each post vertex p is \(\{0\}\cup \{\ell (p),\ldots ,u(p)\}\), where \(\ell (p)\) and u(p) denote the lower and upper quotas of p respectively. Since the empty matching is always feasible in our case, our aim is to find a domaincompatible subgraph \(G'\) such that the total weight of the edges in \(G'\) is maximum.
2 Problem Definition
In this section we provide a formal definition of the maximum weight manytoone matching problem with lower quotas (WMLQ).
Basic Notation Let \(G = (V, E)\) be a graph. For a subset of vertices \(U \subseteq V\) we denote by \(\delta (U) = \{\{ v, w\} \in E : v \in U, w\in V \setminus U\}\) the set of edges incident to exactly one vertex in U. For a vertex \(v \in V\), we write \(\delta (v) = \delta (\{v\})\), and for a subset of edges \(F \subseteq E\) we write \(\deg _F(v) = \delta (v) \cap F\). By \(\varGamma (v) = \{w \in V : \{v, w\} \in E\}\) we denote the neighborhood of v, i.e., the set of vertices that are adjacent to v.
In our problem, a set of applicants A and a set of posts P are given. A and P constitute the two vertex sets of an undirected bipartite graph \(G = (V, E)\) with \(V = A\,\dot{\cup }\, P\) and E represents the set of acceptable applicantpost pairs. Each edge carries a weight \(w: E \rightarrow {\mathbb {R}}_{\ge 0}\), representing the utility of the corresponding assignment. The set of posts is equipped with functions \(\ell : P \rightarrow {\mathbb {Z}}_{\ge 0}\) and \(u: P \rightarrow {\mathbb {Z}}_{\ge 0}\) such that \(\ell (p) \le u(p)\) for every \(p \in P\). Here \(\ell (p)\) is called the lower quota of p and u(p) is called the upper quota of p. These functions bound the number of admissible applicants for the post (independent of the weight of the corresponding edges). Furthermore, every applicant can be assigned to at most one post. Thus, an assignment is a subset \(M \subseteq E\) of the edges such that \(\delta (a) \cap M \le 1\) for every applicant \(a \in A\) and \(\delta (p) \cap M \in \left\{ 0, \ell (p), \ell (p)+1, \ldots , u(p) \right\} \) for every \(p \in P\). With respect to an assignment M, a post is said to be open if the number of applicants assigned to it is greater than 0, and closed otherwise. The size of an assignment M, denoted M, is the number of assigned applicants, while the weight of M, denoted w(M), is the total weight of the edges in M, i.e., \(w(M) = \sum _{e \in M} w(e)\). The goal is to find an assignment of maximum weight. Formally, we define the WMLQ problem as follows.
Problem 1
WMLQ
Input: \({\mathcal {I}} = (G, w, \ell , u)\); a bipartite graph \(G = (A\,\dot{\cup }\,P, E)\) with edge weights w, lower quotas \(\ell \) and upper quotas u.
Task: Find an assignment of maximum weight.
If \(w(e)=1\) for all \(e \in E\), we refer to the problem as mlq.
Remark 1
Note that when lower quotas are present but posts cannot be closed, we obtain the Degree Constrained Subgraph Problem (DCS); a maximum weight matching in an instance of DCS can be found in polynomial time [10]. In the special case that lower quotas are absent, DCS is referred to as the Upper Degree Constrained Subgraph Problem (UDCS) [10].
Some trivial simplification of the instance can be executed right at the start. If \(u(p) > \varGamma (p)\) for a post p, then u(p) can be replaced by \(\varGamma (p)\). On the other hand, if \(\ell (p) > \varGamma (p)\), then post p can immediately be deleted, since no feasible solution can satisfy the lower quota condition. Moreover, a post p with \(\ell (p) = 1\) behaves identically to the case that \(\ell (p) = 0\), so we assume that no post p has \(\ell (p) = 1\). From now on we assume that the instances have already been simplified this way.
3 Degree and QuotaRestricted Cases
In this section we characterize the complexity of WMLQ in the presence of upper bounds placed on vertex degrees or the posts’ upper quotas. Section 3.1 deals with degreerestricted cases, whilst Sect. 3.2 studies cases involving bounded upper quotas.
3.1 DegreeRestricted Cases
In this subsection we will consider WMLQ (i, j), the special case of WMLQ in which \(\varGamma (a)\le i\) for all \(a\in A\), and \(\varGamma (p)\le j\) for all \(p\in P\). That is, every applicant submits at most i applications and every post receives at most j applications. In order to establish our first result, we reduce the maximum independent set problem (mis) to mlq. In mis, a graph with n vertices and m edges is given and the task is to find an independent vertex set of maximum size. mis is not approximable within a factor of \(n^{1\varepsilon }\) for any \(\varepsilon > 0\), unless \(\textsf {P}= \textsf {NP}\) [35]. The problem remains \(\textsf {APX}\)complete even for cubic (3regular) graphs [2].
Theorem 1
mlq(2,3) is \(\textsf {APX}\)complete.
Proof
First of all, mlq(2,3) is in \(\textsf {APX}\) because the problem has a 4approximation that can be found in polynomial time (see Theorem 7).
To each instance \({\mathcal {I}}\) of mis on cubic graphs we create an instance \({\mathcal {I}}'\) of mlq such that there is an independent vertex set of size at least K in \({\mathcal {I}}\) if and only if \({\mathcal {I}}'\) admits an assignment of size at least 3K, yielding an approximationpreserving reduction. The construction is as follows. To each of the n vertices of graph G in \({\mathcal {I}}\), a post with upper and lower quota of 3 is created. The m edges of G are represented as m applicants in \({\mathcal {I}}'\). For each applicant \(a \in A\), \(\varGamma (a) =2\) and \(\varGamma (a)\) comprises the two posts representing the two end vertices of the corresponding edge. Since we work on cubic graphs, \(\varGamma (p) = 3\) for every post \(p \in P\).
First we show that an independent vertex set of size K can be transformed into an assignment of at least 3K applicants. All we need to do is to open a post with its entire neighborhood assigned to it if and only if the vertex representing that post is in the independent set. Since no two posts stand for adjacent vertices in G, their neighborhoods do not intersect. Moreover, the assignment assigns exactly three applicants to each of the K open posts.
To establish the opposite direction, let us assume that an assignment of cardinality at least 3K is given. The posts’ upper and lower quota are both set to 3, therefore, the assignment involves at least K open posts. No two of them can represent adjacent vertices in G, because then the applicant standing for the edge connecting them would be assigned to both posts at the same time.
Note that every solution of the constructed instance of mlq serves an integer multiple of 3 applicants. In particular, the mlq instance has a solution serving 3K applicants if and only if there is an independent set of size K in the mis instance. Hence, this reduction preserves the approximation factors. Since mlq(2,3) belongs to \(\textsf {APX}\) and mis is \(\textsf {APX}\)complete in cubic graphs, it follows that mlq(2,3) is \(\textsf {APX}\)complete. \(\square \)
So far we have established that if \(\varGamma (a) \le 2\) for every applicant \(a \in A\) and \(\varGamma (p) \le 3\) for every post \(p \in P\), then mlq is \(\textsf {NP}\)hard. In the following, we also show that these restrictions are the tightest possible. If \(\varGamma (p) \le 2\) for every post \(p \in P\), then a maximum weight matching can be found efficiently, regardless of \(\varGamma (a)\). Note that the case WMLQ(1,\(\infty \)) is trivially solvable.
Theorem 2
WMLQ(\(\infty \),2) is solvable in \(O(n^2 \log n)\) time, where \(n = A + P\).
Proof
After executing the simplification steps described at the end of Sect. 2, we apply two more changes to derive our helper graph H. Firstly, if \(\ell (p) = 0\), \(u(p) = 2\) and \(\varGamma (p) = 2\), we separate p’s two edges, splitting p into two posts with upper quota 1. After this step, all posts with \(u(p) = 2\) also have \(\ell (p) = 2\). All remaining vertices are of upper quota 1. Then, we substitute all edge pairs of posts with \(\ell (p) = u(p) = 2\) with a single edge connecting the two applicants. This edge will carry the weight equal to the sum of the weights of the two deleted edges.
Clearly, any matching in H translates into an assignment of the same weight in G and vice versa. Finding a maximum weight matching in a general graph \(G=(V, E)\) can be done in \(O(V(E + V \log V))\) time [11], which reduces to \(O(V^2 \log V)\) in our case. \(\square \)
3.2 QuotaRestricted Cases
In this section, we consider restrictions of WMLQ with bounded upper quotas. Note that Theorem 1 already tells us that the case of \(u(p) \le 3\) for all posts \(p \in P\) is \(\textsf {NP}\)hard to solve. We will now settle the complexity of the only remaining case, where we have instances with every post \(p\in P\) having an arbitrary degree and \(u(p) \le 2\). This setting models posts that need to be assigned to none, one or pairs of applicants.
Here we present a solution for WMLQ with \(u(p) \le 2\). Our algorithm is based on ffactors of graphs. In the ffactor problem, a graph G and a function \(f: V \rightarrow {\mathbb {Z}}_{\ge 0}\) is given. A set of edges \(F \subseteq E\) is called an ffactor if \(\deg _F(v) = f(v)\) for every \(v \in V\), where \(\deg _F(v)\), as per our earlier definition, is the degree of v in the graph (V, F). Constructing an ffactor of maximum weight in a graph with n vertices and m edges or proving that none exists can be done in \(O(\phi (m + n \log {n}))\) time, where \(\phi \) is the sum of all fvalues in the graph [10, 11].
Theorem 3
WMLQ with \(u(p) \le 2\) for every \(p \in P\) can be solved in \(O(nm + n^2 \log { n})\) time, where \(n = V\) and \(m = E\).
Proof
We partition P into \(P_1\) and \(P \setminus P_1\), where \(P_1\) denotes the set of posts with \(u(p) = 1\). For posts in \(P \setminus P_1\) we can assume that \(\ell (p) = u(p) = 2\) for every post p. For, a post p with \(\ell (p)=0\) and \(u(p) = 2\) can be transformed into a post with \(\ell (p) = u(p) = 2\) by giving it two dummy edges with zero weight, allowing us to pick the dummy edges in order to make up for the raised lower quota.
The graph \(G' =(V',E')\) of the constructed ffactor instance contains the graph \(G =(V,E)\) of our WMLQ instance, as shown in Fig. 1. We add a dummy post \(p_d\) to \(V'\) and connect it to every applicant in A. We connect every post \(p_i\in P_1\) to \(p_d\). For every post \(p_i\in P\backslash P_1\) we add two dummy vertices \(q_i^1\) and \(q_i^2\) and a triangle on the vertices \(p_i, q_i^1\) and \(q_i^2\). All new edges in \(E' \setminus E\) carry zero weight.

\(\left\{ p_d,a_i\right\} \) for every applicant \(a_i\) that is unmatched in M;

\(\left\{ q_i^1,p_i\right\} \) and \(\left\{ q_i^2,p_i\right\} \) for every post \(p_i\in P\backslash P_1\) that is closed in M;

\(\left\{ q_i^1,q_i^2\right\} \) for every post \(p_i\in P\backslash P_1\) that is open in M;

\(\left\{ p_d,p_i\right\} \) for every post \(p_i \in P_1\) that is closed in M;
It is easy to see that if there is an ffactor \(M'\) in \(G'\), then its restriction to G is a feasible assignment M of the same weight so that the number of unmatched applicants and the number of closed posts in \(P_1\) add up to K. Since every post \(p_i \in P_1\) is connected to \(p_d\) and \(f(p_i) = 1\), it is either the case that \(p_i\) is open in M or \(\{p_d,p_i\}\in M'\). Regarding posts outside of \(P_1\), we need to show that the two edges incident to them are either both in G or neither of them are in G. Assume without loss of generality that \(\{p_i,q_i^1\}\in M'\) and \(\{p_i,q_i^2\}\notin M'\) for some \(p_i \notin P_1\). Since \(f(q_i^2) = 1\) and \(\deg _{M'}(q_i^2) = 0\), \(M'\) cannot be an ffactor.
So far we have shown that it is sufficient to test \(A + P_1 +1\) values for \(f(p_d)\), and collect the optimal assignments given by the maximum weight ffactors. Comparing the weight of these locally optimal solutions delivers a global optimum. A slight modification on the the graph corresponding to the ffactor instance will allow us to solve the problem by constructing just two instances, as against \(A + P_1 +1\) instances. Similar to the triangles attached to posts in \(P \setminus P_1\), triangles are added to \(p_d\) as well. The added vertices have fvalue 1 and the added edges carry weight 0. The number of such triangles hanging on \(p_d\) is \(\left\lceil \frac{A + P_1}{2}\right\rceil \). These triangles can take up all the fvalue of \(p_d\) if necessary, but by choosing the edge not incident to \(p_d\) they can also allow \(p_d\) to fill up its fvalue with other edges. Since a triangle either takes up 0 or 2 of \(p_d\)’s fvalue, we need to separate the two different parity cases. Thus, to cover all the \(A + P_1 + 1\) cases for possible values for \(f(p_d)\), in one instance we set \(f(p_d)\) to \(A + P_1 + 1\) and in the other instance \(f(p_d) = A + P_1\). \(\square \)
4 Bounded Treewidth Graphs
In this section, we investigate WMLQ from the point of view of fixedparameter tractability and analyze how efficiently the problem can be solved for instances with a bounded treewidth. Graphs with bounded treewidth occur frequently in reallife instances of various problems, such as expert systems, evolution theory, or natural language processing [5]. More specifically, WMLQ could be used as a potential modeling approach to handle load balancing in telecommunication networks that requires throughput maximization. In WLAN and P2P networks, servers have limited capacities and in addition the loads need to be reasonably balanced among the active servers [3]. This could be quite efficiently modeled using the upper and lower quotas. Moreover, certain P2P and WLAN networks have bounded treewidth [19].
FixedParameter Tractability This field of complexity theory is motivated by the fact that in many applications of optimization problems certain input parameters stay small even for large instances. A problem, parameterized by a parameter k, is fixedparameter tractable (\(\textsf {FPT}\)) if there is an algorithm solving it in time \(f(k)\cdot \phi (n)\), where \(f : {\mathbb {R}} \rightarrow {\mathbb {R}}\) is a function, \(\phi \) is a polynomial function, and n is the input size of the instance. Note that this definition not only requires that the problem can be solved in polynomial time for instances where k is bounded by a constant, but also that the dependence of the running time on k is separable from the part depending on the input size. On the other hand, if a problem is shown to be \(\textsf {W}[1]\)hard, then the latter property can only be fulfilled if \(\textsf {FPT}= \textsf {W}[1]\), which would imply \(\textsf {NP}\subseteq \textsf {DTIME}(2^{o(n)})\). For more details on fixedparameter algorithms see, e.g., [27].
 1.
Every vertex of G belongs to at least one bag of the tree.
 2.
For every edge \(\{a, p\} \in E(G)\), there is a bag containing both a and p.
 3.
If a vertex in V(G) occurs in two bags of the tree, then it also occurs in all bags on the unique treepath connecting them.

Leaf bag: \(B = 1\) and B has no child;

Introduce bag: B has exactly one child \(B_1\), so that \(B_1 \subset B\) and \(B \setminus B_1 = 1\);

Forget bag: B has exactly one child \(B_1\), so that \(B \subset B_1\) and \(B_1 \setminus B = 1\);

Join bag: B has exactly two children \(B_1\) and \(B_2\), so that \(B = B_1 = B_2\).
In the following, we show that WMLQ is fixedparameter tractable when parameterized simultaneously by the treewidth and \(u_{\max }\), whereas it remains W[1]hard when only parameterized by the treewidth. A similar study of the fixedparameter tractability of the related extended global cardinality constraint problem (EGCC) was conducted in Ref. [32]. EGCC corresponds to the special case of the Dmatching problem where the graph is bipartite and on one side of the bipartition all vertices have the domain \(\{1\}\). In contrast with WMLQ, EGCC is a feasibility problem (note that the feasibility version of WMLQ is trivial, as the empty assignment is always feasible). The authors of [32] provided a fixedparameter algorithm for EGCC when parameterized simultaneously by the treewidth of the graph and the maximum domain size, and they showed that the problem is \(\textsf {W}[1]\)hard when only parameterized by the treewidth. These results mirror our results for WMLQ, and indeed both our FPTalgorithm for WMLQ and the one in Ref. [32] are extensions of the same classic dynamic program for the underlying maximum independent set problem. However, our hardness result uses a completely different reduction than the one in Ref. [32]. The latter makes heavy use of the fact that the domains can be arbitrary sets, whereas in WMLQ, we are confined to intervals.
4.1 Algorithm for Bounded Treewidth Graphs
We will now describe an algorithm for solving WMLQ in polynomial time for graphs with constant treewidth. The algorithm is a dynamic program that inductively computes a set of partial solutions for each bag of the nice tree decomposition and each possible degree profile within that bag. It starts at the leaf bags and then generates partial solutions for each inner node bag by combining or extending partial solutions of its children. The final solution can then be obtained from the root bag. We now formalize the concepts of a partial solution and its corresponding degree profile.
Partial Assignments For any bag B, let \(V_B \subseteq V\) denote the set of vertices contained in the union of bags present in the subtree rooted at B. We define the graph \(G_B = (V_B, E_B)\) with \(E_B := E[V_B] \setminus E[B]\), where E[U] denotes the set of edges with both endpoints in \(U \subseteq V\). A partial assignment for the subtree rooted at a bag B (or partial assignment for B in short) is an assignment \(M \subseteq E_B\) of \(G_B\) such that \(\deg _M(v) = 0\) or \(\ell (v) \le \deg _M(v) \le u(v)\) for all \(v \in V_B \setminus B.\) ^{1} Note that this definition allows applicants and posts in B to have an arbitrary assignment, which is not restricted by their corresponding quota and that by definition of \(G_B\), no vertex in B is assigned to another vertex in B.
Notation Before we proceed with the formal statement of the lemmas, we introduce some useful notation. For \(U' \subseteq U\) and \(\alpha \in {\mathbb {Z}}^U\) define \(\alpha _{U'}\) as the restriction of \(\alpha \) to \(U'\), i.e., \(\alpha _{U'} \in {\mathbb {Z}}^{U'}\) and \(\alpha _{U'}(v) = \alpha (v)\) for all \(v \in U'\). For \(v \in V \setminus U\) and \(i \in {\mathbb {Z}}\) let further \([\alpha , i]_v\) be the extension of \(\alpha \) to \(U \cup \{v\}\) defined by \([\alpha , i]_v(v') := \alpha (v')\) for all \(v' \in U\) and \([\alpha , i]_v(v) := i\). For a set of edges S we define the vector \(\alpha _{S, U} \in {\mathbb {Z}}^{U}\) by \(\alpha _{S, U}(v) := \deg _S(v)\) for all \(v\in U\).
We first observe that for leaf bags, the only partial assignment possible is the empty assignment.
Lemma 1
Let \(B = \{v\}\) be a leaf bag and let \(\alpha \in X_B\). If \(\alpha (v) = 0\), then \({\mathcal {M}}^*_B(\alpha ) = \{M_{\emptyset }\}\), where \(M_{\emptyset }\) is the empty assignment. If \(\alpha (v) \ne 0\), then \({\mathcal {M}}^*_B(\alpha ) = \emptyset \).
Proof
This follows directly from the fact that \(E_B = \emptyset \) for all leaf bags and thus the only assignment in \(G_B\) is the empty assignment. \(\square \)
For introduce bags, the set of partial assignments is identical to that of its child, extending the degree profiles by a 0entry for the new vertex.
Lemma 2
Proof
Note that \(\varGamma (v') \cap V_B \subseteq B\) by Properties 2 and 3 of a tree decomposition. This implies \(\delta (v') \cap E_B = \emptyset \) and hence the lemma follows. \(\square \)
For a forget bag, every partial assignment corresponds to the union of a partial assignment for its child bag and a subset of edges incident to the removed vertex (connecting it to the vertices in forget bag).
Lemma 3
Proof
Thus let \(M^* := M \cup S^*\). Observe that indeed \(\deg _{M^*}(v) = \deg _M(v) + \deg _{S^*}(v) = \alpha (v)  \alpha _{S^*, B}(v) + \alpha _{S^*, B}(v) = \alpha (v)\) for all \(v \in B\). Furthermore \(\deg _{M^*}(v) = \deg _M(v) \in \{0, \ell (v), \ldots , u(v)\}\) for all \(v \in V_B \setminus B'\) by feasibility of M. Finally, \(\deg _{M^*}(v') = i^* \in \{0, \ell (v'), \ldots , u(v')\}\), implying \(M^* \in {\mathcal {M}}_B(\alpha )\). As \(w(M^*) = w(S^*) + W_{B'}([\alpha  \alpha _{S^*},\, i^*  S^*]_{v'}) \ge w(M')\), we conclude that indeed \(M^* \in {\mathcal {M}}^*_B(\alpha )\). \(\square \)
For join bags, every partial assignment is a union of partial assignments for the two child bags.
Lemma 4
Proof
Now let \(M' \in {\mathcal {M}}_B(\alpha )\). Let \(M'_1 := M' \cap E_{B_1}\) and \(M'_2 := M' \cap E_{B_2}\). We observe that \((\alpha _{M_1, B_1}, \alpha _{M_2, B_2})\) is a feasible solution to [join] and hence \(w(M') = w(M'_1) + w(M'_2) \le w(M_1) + w(M_2) = w(M^*)\). \(\square \)
Finally, we observe that after computing \(W_R(\alpha )\) and the corresponding elements of \({\mathcal {M}}^*_R(\alpha )\) for each \(\alpha \) for the root bag R, an optimal assignment for G can be easily obtained.
Lemma 5
Proof
Let \(M^* := S^* \cup M\) for some \(M \in {\mathcal {M}}^*_R(\alpha ^*)\). Note that for \(v \in V \setminus R\), we have \(S^* \cap \delta (v) = \emptyset \) and hence \(\deg _{M^*}(v) = \deg _M(v) \in \{0, \ell (v), \ldots , u(v)\}\) by the feasibility of M. Furthermore, for \(v \in R\), we have \(\deg _{M^*}(v) = \alpha ^*(v) + \deg _{S^*}(v) \in \{0, \ell (v), \ldots , u(v)\}\) by the feasibility of \(S^*\) for [root]. We conclude that \(M^*\) is indeed a feasible solution to WMLQ.
Theorem 4
WMLQ can be solved in time \(O(T + (u_{\max })^{3{\text {tw}}(G) + 3}E)\), where T is the time needed for computing a tree decomposition of G of width \({\text {tw}}(G)\). In particular, WMLQ can be solved in polynomial time when restricted to instances of bounded treewidth, and WMLQ parameterized by \(\max \{{\text {tw}}(G), u_{\max }\}\) is fixedparameter tractable.
Proof
In order to solve a given WMLQ instance, the algorithm starts by computing a nice tree decomposition of G of width \({\text {tw}}(G)\). Note that T is of the same order for tree decompositions and nice tree decompositions. Using Lemmas 1–5, we can inductively compute a representative \(M \in {\mathcal {M}}^*_B(\alpha )\) for every bag B and every \(\alpha \in X_b\), or deduce that \({\mathcal {M}}^*_B(\alpha ) = \emptyset \). We first observe that \(X_B = (u_{\max } + 1)^{B}\), thus only \((u_{\max } + 1)^{{\text {tw}}(G) + 1}\) representatives have to be computed per bag. Furthermore, for each of the above lemmas, the necessary computations to derive an \(M \in {\mathcal {M}}^*_B(\alpha )\) from representatives of \({\mathcal {M}}^*_{B'}(\alpha ')\) of children \(B'\) of B can be done in time \(O((u_{\max })^{2{\text {tw}}(G) + 2})\). This is obvious for Lemmas 1 and 2. For Lemmas 3–5 we observe that the sets of feasible solutions for the corresponding optimization problems [forget], [join], and [root] have size at most \(2^{B} \cdot (u_{\max } + 1)\), \((u_{\max } + 1)^{2B}\), and \(2^{R^2} \cdot (u_{\max })^{R}\), respectively (note that without loss of generality we can assume R to be of constant size by introducing at most \({\text {tw}}(G)\) additional forget bags). The theorem then follows from the fact that the number of bags is linear. \(\square \)
4.2 \(\textsf {W}[1]\)Hardness for Parameterizing by Treewidth Only
While our algorithm runs in polynomial time for bounded treewidth, the degree of the polynomial depends on the treewidth and the algorithm only becomes a fixedparameter algorithm when parameterizing by treewidth and \(u_{\max }\) simultaneously. We will now show by a reduction from Minimum Maximum Outdegree that this dependence is necessary under the assumption that \(\textsf {FPT}\ne \textsf {W}[1]\).
Problem 2
Minimum Maximum Outdegree
Input: A graph \(G = (V, E)\), edge weights \(w: E \rightarrow {\mathbb {Z}}_+\) encoded in unary and a degreebound \(r \in {\mathbb {Z}}_+\).
Task: Find an orientation D of G such that \(\sum _{e \in \delta _D^+(v)} w(e) \le r\) for all \(v \in V\), where \(\delta _D^+(v)\) stands for the set of edges oriented so that their tail is v.
Theorem 5
(Theorem 5 from [34]) Minimum Maximum Outdegree is W[1]hard when parameterized by treewidth.
Theorem 6
mlq is \(\textsf {W}[1]\)hard when parameterized by treewidth, even when restricted to instances where \(\ell (p) \in \{0, u(p)\}\) for every \(p \in P\).
Proof

For every vertex \(v \in V\) we introduce a post \(p_{v} \in P\) with lower quota \(\ell (p_{v}) = 0\) and upper quota \(u(p_{v}) = r\).
 For every edge \(e = \{v, v'\} \in E\), we introduce two posts \(p_{e,v} \) and \(p_{e,v'} \) with identical lower and upper quotas of \(w(e)+1\), i. e. ,We also add \(2w(e) + 1\) applicants \( a^{1}_{e,v}, \ldots , a^{w(e)}_{e,v}, a^{1}_{e,v'}, \ldots , a^{w(e)}_{e,v'}, z_{e} \), which are connected to the posts by the edges$$\begin{aligned} \ell (p_{e,v}) = \ell (p_{e,v'}) = u(p_{e,v}) = u(p_{e,v'}) = w(e) + 1. \end{aligned}$$as well as \(\{p_{e,v}, z_{e} \}\) and \(\{ z_{e}, p_{e,v'} \}\). This construction is shown in Fig. 2.$$\begin{aligned} \left\{ p_{v}, a^{i}_{e,v} \right\} ,\left\{ a^{i}_{e,v}, p_{e,v} \right\} , \left\{ p_{v'}, a^{i}_{e,v'} \right\} , \left\{ a^{i}_{e,v'}, p_{e,v'} \right\} \,\, \text { for } i \in \{1, \ldots , w(e)\} \end{aligned}$$
We show that the constructed instance has a solution serving all applicants if and only if the Minimum Maximum Outdegree instance has an orientation respecting the bound on the weighted outdegree.
First assume there is an orientation D of G with maximum weighted outdegree at most r. Then consider the assignment that assigns for every oriented edge \((v, v') \in D\) the w(e) applicants \(a^i_{e, v}\) to \(p_v\) and the \(w(e) + 1\) applicants \(a^i_{e, v'}\) and \(z_e\) to \(p_{e, v'}\). As the weighted outdegree of vertex v is at most r, every post \(p_{v}\) gets assigned at most \(r = u(p_v)\) applicants.
Now assume M is a feasible assignment of applicants to posts serving every applicant. In particular, for every edge \(e = \{v,v'\} \in E\), applicant \(z_e\) is assigned to either \(p_{e, v}\) or \(p_{e, v'}\) and exactly one of these two posts is open because the lower bound of \(w(e) + 1\) can only be met if \(z_e\) is assigned to the respective post. If \(p_{e, v}\) is open then all w(e) applicants \(a^i_{e, v'}\) are assigned to \(p_{v'}\) and none of the applicants \(a^i_{e, v}\) is assigned to \(p_{v}\), and vice versa if \(p_{e, v'}\) is open. Consider the orientation obtained by orienting every edge e from v to \(v'\) if and only if \(p_{e, v}\) is open. By the above observations, the weighted outdegree of vertex v corresponds to the number of applicants assigned to post \(p_v\), which is at most r.
Finally, note that \(G'\) can be constructed in time polynomial in the input size of the Minimum Maximum Outdegree instance as the weights are encoded in unary there. Furthermore, the treewidth of \(G'\) is at most \(\max \{{\text {tw}}(G), 3\}\). To see this, start with a tree decomposition of G and identify each vertex \(v \in V\) with the corresponding post \(p_v\). For every edge \(e = \{v, v'\} \in E\), there is a bag B with \(p_v, p_v' \in B\). We add the new bag \(B_e = \{p_v, p_v', p_{e, v}, p_{e, v'}\}\) as a child to B. We further add the bags \(B_{z_e} = \{p_{e, v}, p_{e, v'}, z_e\}\), \(B_{a^i_{e,v}} = \{p_v, p_{e, v}, a^i_{e,v}\}\) and \(B_{a^i_{e,v'}} = \{p_{v'}, p_{e, v'}, a^i_{e,v'}\}\) for \(i \in \{1, \ldots , w(e)\}\) as children to \(B_e\). Observe that the tree of bags generated by this construction is a tree decomposition. Furthermore, since we did not increase the size of any of the existing bags and added only bags of size at most 4, the treewidth of \(G'\) is at most \(\max \{{\text {tw}}(G), 3\}\). \(\square \)
5 Approximation
Having established the hardness of WMLQ even for very restricted instances in Theorem 1, we turn our attention towards approximability. In this section, we give an approximation algorithm and corresponding inapproximability bounds expressed in terms of A, P and upper quotas in the graph.
Remark 2
As an alternative to Algorithm 1, one could use a reduction from WMLQ to the set packing problem. The elements in the universe of the set packing problem would be \(A\cup P\). For each post p and for each subset \(S \subset \varGamma (p)\), such that \(l(p) \le S \le u(p)\), we create a set \(S \cup \{p\}\) for the set packing instance. A feasible set packing then corresponds to a feasible assignment of the same weight. However, if the difference between p’s upper and lower quota is not bounded by a constant, this would create an exponentialsized input for the set packing problem and we could only employ an oraclebased algorithm known for the set packing problem to solve WMLQ. The greedy algorithm known for the set packing problem [7] can be made to work in a fashion similar to the algorithm presented above.
In the following we give a tight analysis of the algorithm, establishing approximation guarantees in terms of the number of posts P, the number of applicants A, and the maximum upper quota \(u_{\max } := \max _{p \in P} u(p)\) over all posts. We also provide two examples that show that our analysis of the greedy algorithm is tight for each of the described approximation factors. We further show that the approximation ratios given above for WMLQ are almost tight from the point of view of complexity theory.
Theorem 7
Algorithm 1 is an \(\alpha \)approximation algorithm for WMLQ with \(\alpha = \min \{P,\, A,\, u_{\max } + 1\}\). Furthermore, for mlq, Algorithm 1 is a \(\sqrt{A} + 1\)approximation algorithm. It can be implemented to run in time \(O(E \log E)\).
Proof
Let \(p'_i\) be the post chosen by the algorithm in iteration i and let \(A'_i\) be the corresponding set of applicants for every \(i \in \{1, \ldots , n\}\). Furthermore, consider an optimal solution of weight \(OPT \), consisting of open posts \(p_1, \ldots , p_k\) and the corresponding sets of applicants \(A_1, \ldots , A_k\) assigned to those posts.
We first observe that the first two approximation ratios of P and A are already achieved by the initial selection of \(p'_1\) and \(A'_1\) chosen in the first round of the algorithm. For every \(i \in \{1, \ldots , k\}\), post \(p_i\) is an admissible post in the first iteration of the algorithm. The first iteration’s choice of the pair \((p'_1, A'_1)\) implies \(\sum _{a \in A'_1} w(a, p'_1) \ge \sum _{a \in A_i} w(a, p_i) \ge w(a', p_i)\) for every \(a' \in A_i\). As the optimal solution opens at most P posts and serves at most A applicants, we deduce that \(\min \{P, A\} \cdot \sum _{a \in A'_1} w(a, p'_1) \ge OPT \).
We now turn to proving the bound on the running time. We will describe how to implement the search for the greedy choice of the pair \((p', A')\) in each iteration efficiently using a heap data structure. Initially, for every post p, we sort the applicants in its neighborhood by nonincreasing order of w(a, p). This takes time at most \(O(E \log E)\) as the total number of entries to sort is \(\sum _{p \in P} \varGamma (p) = E\). We then introduce a heap containing all admissible posts, and associate with each post p the total weight of the first u(p) edges in its neighborhood list. Note that these entries can be easily kept up to date whenever the algorithm opens a post and assigns applicants to it: In the list of every other post p we simply replace the assigned applicants with the first notyetassigned entry in the list (or we remove the post if less than \(\ell (p)\) applicants are available). As every edge in the graph can only trigger one such replacement, only O(E) updates can occur and each of these requires \(O(\log P)\) time for reinserting the post at the proper place in the heap. Now, in each iteration of the algorithm, the optimal pair \((p', A')\) can be found by retrieving the maximum element from the heap. This happens at most P times and requires \(O(\log P)\) time in each step. \(\square \)
Example 8
 (a)
The bounds P and \(u_{\max } + 1\) are tight, and \(\sqrt{A} + 1\) is asymptotically tight:
Consider an instance of mlq with \(k + 1\) posts \(p_0, \ldots , p_k\) and \(k(k + 1)\) applicants \(a_{0,1}, \ldots , a_{0,k}, a_{1,1}, \ldots , a_{k,k}\). Let \(\ell (p_i) = u(p_i) = k\) for \(i \in \{0, \ldots , k\}\). Each applicant \(a_{i,j}\) applies to post i, and if \(i>0\), additionally to post 0. For the greedy algorithm, opening post \(p_0\) and assigning applicants \(a_{1,1}, \ldots , a_{k,k}\) to it is a valid choice in its first iteration, after which no further posts are admissible. Thus, it only assigns k applicants in total. The optimal solution, however, can assign all \(k(k+1)\) applicants by assigning applicants \(a_{i,1}, \ldots , a_{i,k}\) to \(p_i\) for each i. Therefore, the greedy algorithm cannot achieve an approximation factor better than \(k + 1\) on this family of instances, for which \(P = k+1\), \(\sqrt{A} < k+1\), and \(u_{\max } = k\).
 (b)
The bound A is tight:
To see that the approximation ratio of A is tight for WMLQ consider the following instance with k posts \(p_1, \ldots , p_k\) and k applicants \(a_1, \ldots , a_k\). Let \(\ell (p_i) = 0\) and \(u(p_i) = k\) for every i. Every applicant applies for every post, and \(w(a_i, p_i) = 1\) for every i but \(w(a_i, p_j) = \varepsilon \) for every \(j \ne i\) for some arbitrarily small \(\varepsilon > 0\). In its first iteration, the greedy algorithm might choose to open post \(p_1\) and assign all applicants to it. This solution accumulates a weight of \(1 + (k  1)\varepsilon \), while the weight of the optimal solution is \(k = A\).
Theorem 9
mlq is not approximable within a factor of \(P^{1\varepsilon }\) or \(\sqrt{A}^{1\varepsilon }\) or \(u_{\max }^{1\varepsilon }\) for any \(\varepsilon > 0\), unless \(\textsf {P}= \textsf {NP}\), even when restricting to instances where \(\ell (p) = u(p)\) for every \(p \in P\) and \(\varGamma (a) \le 2\) for every \(a \in A\).
Proof
Note that due to the choice of upper and lower bounds, any open post must be assigned to all the applicants in its neighborhood. Thus, a solution to the mlq instance is feasible if and only if \(\varGamma (p_i) \cap \varGamma (p_j) = \emptyset \) for all open posts \(p_i\) and \(p_j\) with \(i \ne j\), which is equivalent to \(v_i\) and \(v_j\) not being adjacent in G by construction of the instance. Therefore, the mlq instance has a feasible solution opening k posts (and thus serving kn applicants) if and only if there is an independent set of size k in G. We conclude that \(OPT _{\textsc {mlq}} = n \cdot OPT _{\textsc {mis}}\) for the two instances under consideration.
Note that in the constructed mlq instance, \(n =P = u_{\max } \ge \sqrt{A}\). Therefore any approximation algorithm with a factor better than \(P^{1\varepsilon }\) or \(\sqrt{A}^{1\varepsilon }\) or \(u_{\max }^{1\varepsilon }\) for \(\varepsilon > 0\) yields a solution of the instance that serves at least \((1/n^{1\varepsilon }) OPT _{\textsc {mlq}}\) applicants and therefore opens at least \((1/n^{2\varepsilon }) OPT _{\textsc {mlq}} = (1/n^{1  \varepsilon }) OPT _{\textsc {mis}}\) posts, corresponding to an independent set of the same size. By Ref. [35], this implies \(\textsf {P}= \textsf {NP}\). \(\square \)
6 Matchings with Lower Quotas in General Graphs
Throughout this paper, we focused on manytoone matchings in bipartite graphs because these fit most applications in the centralized formation of groups that motivated our investigation. A straightforward generalization of WMLQ to matchings in an arbitrary (not necessarily bipartite) graph G allows all vertices of the graph to have lower and upper quotas.
Problem 3
gwmlq
Input: \({\mathcal {I}} = (G, w, \ell , u)\); a not necessarily bipartite graph \(G = (V, E)\) with edge weights w, lower quotas \(\ell \) and upper quotas u.
Task: Find an assignment of maximum weight.
If \(w(e)=1\) for all \(e \in E\), we refer to the problem as gmlq.
One can see this generalization as a variant of the Dmatching problem (see Sect. 1.1), where each vertex has a domain consisting of 0 and an interval. Clearly, the hardness results derived in the previous sections are valid for gwmlq as well. We now briefly argue that the positive results from Sects. 3 and 4 carry over to this generalized setting. However, our approximation results do not hold even if G is bipartite and only a single applicant is equipped with lower and upper quotas. In fact, gwmlq does not allow for any approximation even in this very restricted case unless \(\textsf {P}=\textsf {NP}\).
The two positive results in Sect. 3, namely Theorems 2 and 3, are applicable to gwmlq. Note that Theorem 2 (bounded degree for all posts) is a special case of Theorem 3 (bounded upper quota for all posts).
Theorem 10
gwmlq can be solved in polynomial time when restricted to instances with \(u(v) \le 2\) for all \(v \in V\).
Proof
We will work with the proof of Theorem 3, which requires some simple modifications to fit the case of arbitrary graphs. All we need to do is to add a dummy vertex \(v_d\) to G—this resembles dummy post \(p_d\) in the proof of Theorem 3. The steps corresponding to a post vertex should now be executed for all vertices of the graph. We can assume there are no vertices with lower quota 0 and upper quota 2 by a similar reasoning given in Theorem 2. For every vertex \(v_i\) with \( \ell (v_i) = 2\), we add two dummy vertices \(q_i^1\) and \(q_i^2\) and connect them to each other and \(v_i\). For all of these vertices, we set \(\ell (q^1_i) = u(q^1_i) = \ell (q^2_i) = u(q^2_i) =1\). Then, the dummy vertex \(v_d\) is connected to vertices with upper quota 1. We finish the construction by adding triangles to \(v_d\) to ensure that only two ffactors need to be computed. The arguments in the proof of Theorem 3 can now be applied to this ffactor instance. \(\square \)
As for Theorem 4, the algorithm for bounded treewidth and upper quota carries over to gwmlq without any modification. Note that in the proof we never used the bipartiteness of G or that \(u(a) =1\) for the applicants.
Theorem 11
gwmlq can be solved in time \(O(T + (u_{\max })^{3{\text {tw}}(G) + 3}E)\), where T is the time needed for computing a tree decomposition of G of width \({\text {tw}}(G)\). In particular, gwmlq can be solved in polynomial time when restricted to instances of bounded treewidth, and WMLQ parameterized by \(\max \{{\text {tw}}(G), u_{\max }\}\) is fixedparameter tractable.
Finally, we prove that Algorithm 1 cannot be generalized even for bipartite mlq with lower and upper quotas on both sides.
Theorem 12
It is \(\textsf {NP}\)hard to decide whether \(OPT > 0\) for an instance of gmlq, even if the graph is bipartite and on one side of the bipartition all vertices except for one have unitary upper and lower quota.
Proof
Since every post is adjacent to exactly \(n + 1\) applicants, opening a post requires allocating all its applicants to it, including \(a_d\) as well. Thus, opening any post implies allocating \(a_d\) to exactly K posts. These K open posts do not share applicants other than \(a_d\), which is equivalent to the K vertices corresponding to them in the mis instance forming an independent set. \(\square \)
7 Conclusion
We discussed the complexity, approximability and fixedparameter tractability of WMLQ from various viewpoints such as bounded degree, quota and treewidth.
Further work on the topic might include imposing common quotas on some groups of posts. That is, we may have subsets \(P_1,\ldots ,P_k\), where for each i (\(1\le i\le k\)), \(P_i\subseteq P\), \(P_i\) has a common quota \(u(P_i)\ge 1\), where \(u(P_i)\le \sum _{p\in P_i}u(p)\), and any assignment M must now satisfy the additional property that \(\sum _{p\in P_i} \delta (p)\cap M\le u(P_i)\). Common quotas are similar to regional caps studied in Economics [17] and they can model constraints such as the limited availability of resources required for certain projects—for example \(P_1\) might correspond to those projects that require access to highperformance computing facilities.
We have seen that WMLQ as defined in Problem 1 has a natural application in the context of student–project allocation, where the weight on a given edge (s, p) corresponds to the utility of student s being assigned to project p. However in many applications students have ordinal preferences over projects. Cardinal utilities can of course follow from these via the use of Borda scores, so we can obtain WMLQ as before. But ordinal preferences themselves allow alternative optimality criteria to be formulated. For example we may optimize on the profile of a matching M, which is a vector whose ith position indicates the number of students who obtain their ithchoice project in M [24]. A greedy maximum matching is a matching whose profile is lexicographically maximum, taken over all maximum cardinality matchings, whilst a generous maximum matching is a matching whose reverse profile is lexicographically minimum, taken over all maximum cardinality matchings. There are efficient algorithms to find greedy and generous maximum matchings in the absence of lower quotas [21], but it remains open to extend the positive results in this paper to the setting involving both lower quotas and preferences.
Footnotes
 1.
For ease of exposition, we define \(\ell (a) := u(a) := 1\) for all \(a \in A\). Also recall that \(\deg _S(v) := \delta (v) \cap S\).
Notes
Acknowledgements
We would like to thank András Frank and Kristóf Bérczi for their observations that led us to Theorem 3. We would also like to thank the anonymous reviewers for their valuable comments, which have helped to improve the presentation of this paper.
References
 1.Abraham, D.J., Irving, R.W., Manlove, D.F.: Two algorithms for the student–project allocation problem. J. Discrete Algorithms 5(1), 79–91 (2007)MathSciNetCrossRefzbMATHGoogle Scholar
 2.Alimonti, P., Kann, V.: Some APXcompleteness results for cubic graphs. Theor. Comput. Sci. 237(1–2), 123–134 (2000)MathSciNetCrossRefzbMATHGoogle Scholar
 3.Bejerano, Y., Han, S.J.: Cell breathing techniques for load balancing in wireless lans. IEEE Trans. Mob. Comput. 8(6), 735–749 (2009)CrossRefGoogle Scholar
 4.Biró, P., Fleiner, T., Irving, R.W., Manlove, D.F.: The College Admissions problem with lower and common quotas. Theor. Comput. Sci. 411, 3136–3153 (2010)MathSciNetCrossRefzbMATHGoogle Scholar
 5.Bodlaender, H.L.: A tourist guide through treewidth. Acta Cybern. 11(1–2), 1 (1994)MathSciNetzbMATHGoogle Scholar
 6.Bodlaender, H.L.: A lineartime algorithm for finding treedecompositions of small treewidth. SIAM J. Comput. 25(6), 1305–1317 (1996)MathSciNetCrossRefzbMATHGoogle Scholar
 7.Chandra, B., Halldórsson, M.M.: Greedy local improvement and weighted set packing approximation. J. Algorithms 39(2), 223–240 (2001)MathSciNetCrossRefzbMATHGoogle Scholar
 8.Cornuéjols, G.: General factors of graphs. J. Comb. Theory Ser. B 45(2), 185–198 (1988)MathSciNetCrossRefzbMATHGoogle Scholar
 9.Fragiadakis, D., Iwasaki, A., Troyan, P., Ueda, S., Yokoo, M.: Strategyproof matching with minimum quotas. ACM Trans. Econ. Comput. 4(1), 6:1–40 (2016)MathSciNetCrossRefGoogle Scholar
 10.Gabow, H.N.: An efficient reduction technique for degreeconstrained subgraph and bidirected network flow problems. In: Proceedings of STOC ’83: The 15th Annual ACM Symposium on Theory of Computing, pp. 448–456. ACM (1983)Google Scholar
 11.Gabow, H.N.: Data structures for weighted matching and nearest common ancestors with linking. In: Proceedings of SODA ’90: The 1st ACMSIAM Symposium on Discrete Algorithms, pp. 434–443. ACMSIAM (1990)Google Scholar
 12.Goto, M., Hashimoto, N., Iwasaki, A., Kawasaki, Y., Ueda, S., Yasuda, Y., Yokoo, M.: Strategyproof matching with regional minimum quotas. In: Proceedings of the AAMAS ’14: The 13th International Conference on Autonomous Agents and Multiagent Systems, pp. 1225–1232. IFAAMAS (2014)Google Scholar
 13.Goto, M., Kurata, R., Hamada, N., Iwasaki, A., Yokoo, M.: Improving fairness in nonwasteful matching with hierarchical regional minimum quotas. In: Proceedings of AAMAS ’15: The 14th International Conference on Autonomous Agents and Multiagent Systems, pp. 1887–1888. IFAAMAS (2015)Google Scholar
 14.Hamada, K., Iwama, K., Miyazaki, S.: The hospitals/residents problem with lower quotas. Algorithmica 74(1), 440–465 (2014)MathSciNetCrossRefzbMATHGoogle Scholar
 15.Hanna, J.P., Albert, M., Chen, D., Stone, P.: Minimum cost matching for autonomous carsharing. IFAC PapersOnLine 49(15), 254–259 (2016)MathSciNetCrossRefGoogle Scholar
 16.Iwama, K., Miyazaki, S., Yanagisawa, H.: Improved approximation bounds for the student–project allocation problem with preferences over projects. J. Discrete Algorithms 13, 59–66 (2012)MathSciNetCrossRefzbMATHGoogle Scholar
 17.Kamada, Y., Kojima, F.: Stability and strategyproofness for matching with constraints: a problem in the Japanese medical match and its solution. Am. Econ. Rev. 102(3), 366–370 (2012)CrossRefGoogle Scholar
 18.Kamiyama, N.: A note on the serial dictatorship with project closures. Oper. Res. Lett. 41, 559–561 (2013)MathSciNetCrossRefzbMATHGoogle Scholar
 19.Klasing, R., Kosowski, A., Navarra, A.: Cost minimization in wireless networks with a bounded and unbounded number of interfaces. Networks 53(3), 266–275 (2009)MathSciNetCrossRefzbMATHGoogle Scholar
 20.Kloks, T.: Treewidth, Computations and Approximations, volume 842 of Lecture Notes in Computer Science. Springer, Berlin (1994)Google Scholar
 21.Kwanashie, A., Irving, R.W., Manlove, D.F., Sng, C.T.S.: Profilebased optimal matchings in the Student/Project Allocation problem. In: Proceedings of IWOCA ’14: The 25th International Workshop on Combinatorial Algorithms, volume 8986 of Lecture Notes in Computer Science, pp. 213–225. Springer (2015)Google Scholar
 22.Lovász, L.: On the structure of factorizable graphs. Acta Math. Acad. Sci. Hung. 23(1–2), 179–195 (1972)MathSciNetCrossRefzbMATHGoogle Scholar
 23.Lovász, L.: Antifactors of graphs. Period. Math. Hung. 4(2–3), 121–123 (1973)MathSciNetCrossRefzbMATHGoogle Scholar
 24.Manlove, D.F.: Algorithmics of Matching Under Preferences. World Scientific, Singapore (2013)CrossRefzbMATHGoogle Scholar
 25.Manlove, D.F., O’Malley, G.: Student project allocation with preferences over projects. J. Discrete Algorithms 6, 553–560 (2008)MathSciNetCrossRefzbMATHGoogle Scholar
 26.Monte, D., Tumennasan, N.: Matching with quorums. Econ. Lett. 120, 14–17 (2013)MathSciNetCrossRefzbMATHGoogle Scholar
 27.Niedermeier, R.: Invitation to FixedParameter Algorithms. Oxford University Press, Oxford (2006)CrossRefzbMATHGoogle Scholar
 28.Ólafsson, S.: Weighted matching in chess tournaments. J. Oper. Res. Soc. 41(1), 17–24 (1990)MathSciNetCrossRefzbMATHGoogle Scholar
 29.Plummer, M.D.: Graph factors and factorization: 1985–2003: a survey. Discrete Math. 307(7–8), 791–821 (2007)MathSciNetCrossRefzbMATHGoogle Scholar
 30.Renda, M.E., Straccia, U.: Web metasearch: rank vs. score based rank aggregation methods. In: Proceedings of the 2003 ACM Symposium on Applied Computing, SAC ’03, pp. 841–846, New York. ACM (2003)Google Scholar
 31.Röllin, S., Schenk, O.: Maximumweighted matching strategies and the application to symmetric indefinite systems. In: Dongarra, J., Madson, K., Wasniewski, J. (eds.) Applied Parallel Computing, State of the Art in Scientific Computing, 7th International Workshop, PARA 2004, Lyngby, Denmark, June 20–23, 2004, pp. 808–817. Springer, Berlin Heidelberg (2006)Google Scholar
 32.Samer, M., Szeider, S.: Tractable cases of the extended global cardinality constraint. Constraints 16, 1–24 (2011)MathSciNetCrossRefzbMATHGoogle Scholar
 33.Sebő, A.: General antifactors of graphs. J. Comb. Theory Ser. B 58(2), 174–184 (1993)MathSciNetCrossRefzbMATHGoogle Scholar
 34.Szeider, S.: Not so easy problems for tree decomposable graphs. CoRR. arXiv:1107.1177 (2011)
 35.Zuckerman, D.: Linear degree extractors and the inapproximability of max clique and chromatic number. Theory Comput. 3(6), 103–128 (2007)MathSciNetCrossRefzbMATHGoogle Scholar
Copyright information
Open AccessThis article is distributed under the terms of the Creative Commons Attribution 4.0 International License (http://creativecommons.org/licenses/by/4.0/), which permits unrestricted use, distribution, and reproduction in any medium, provided you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons license, and indicate if changes were made.