arXiv:1301.2342v2 [cs.DS] 21 Jan 2013 A Linear Time Algorithm for the Feasibility of Pebble Motion on Graphs∗ Jingjin Yu Abstract Given a connected, undirected, simple graph G = (V,E) and p ≤|V| pebbles labeled 1,..., p, a configuration of these p pebbles is an injective map assigning the pebbles to vertices of G. Let S and D be two such configurations. From a configuration, pebbles can move on G as follows: In each step, at most one pebble may move from the vertex it currently occupies to an adjacent unoccupied vertex, yielding a new configuration. A natural question in this setting is the following: Is configuration D reachable from S and if so, how? We show that the feasibility of this problem can be decided in time O(|V|+|E|). 1 Introduction In Sam Loyd’s 15-puzzle [4], a player is asked to arrange square game pieces labeled 1-15, scrambled on a 4 × 4 grid, to a shuffled row major ordering, using one empty swap cell: In each step, one of the labeled pieces neighboring the empty cell may be moved to the empty cell (see, e.g., Fig. 1). As early as 1879, Story [5] observed that the feasibility of a 15-puzzle instance is solely decided by the parity of the starting configuration (with respect to the fixed goal configuration). 1 2 15 3 14 12 13 11 10 8 9 7 6 5 4 1 2 15 3 14 12 13 11 10 8 9 7 6 5 4 (a) (b) Figure 1: Two 15-puzzle instances. a) An unsolved instance. In the next step, one of the pieces labeled 5, 6, 14 may move to the vacant cell, leaving behind it another vacant cell for the next move. b) The solved instance. ∗Jingjin Yu is with the Department of Electrical and Computer Engineering, University of Illinois at Urbana-Champaign, Urbana, IL 61801 USA. E-mail: jyu18@uiuc.edu. This research was supported in part by NSF grant 0904501 (IIS Robotics), NSF grant 1035345 (Cyberphysical Systems), and MURI/ONR grant N00014-09-1-1052. 1 Generalizing the 15-puzzle to having n −1 labeled pebbles on an arbitrary non- separable graph G with n vertices, Wilson [7] formalized the observation of Story by showing that if G is bipartite, the reachable configurations from a given start configura- tion form an alternating group on n −1 letters, partitioning all possible configurations into two equivalence classes. If G is non bipartite (except for a special θ0 graph with seven vertices), then the reachable configurations form the symmetric group on n −1 letters, implying that the problem is always feasible. The result by Wilson also yields an algorithm for solving a given instance. However, the number of moves involved may be exponential. Taking a further step, Kornhauser, Miller, and Spirakis [3] studied the pebble motion problem on an arbitrary connected n-vertex graph with up to n −1 peb- bles. For this problem, they gave a polynomial time algorithm that produces solutions with a O(n3) upper bound on the number of moves. As pointed out in [3], certain instances of the pebble motion problem require Θ(n3) moves, suggesting an Ω(n3) lower bound on any algorithm that computes a step-by- step plan for moving the pebbles. Since not all instances of the pebble motion problem can be solved, if the feasibility test can be performed faster than Θ(n3), unnecessary computation on infeasible instances can be avoided. Auletta et al. [1] showed that for trees, deciding whether an given instance of the pebble motion problem is feasible can be done in linear time. Recently, Goraly and Hassin [2] extended the result to graphs. We independently reach the same conclusion via a direct reduction to the tree approach proposed in [1]. The tree that we obtain shrinks the graph significantly wheres the method in [2] adds more vertices to the graph. The pebble motion problem on graphs finds applications in multi-robot path plan- ning, deflection routing in data networks, and memory management in distributed sys- tems. Fast feasibility test for this problem can help eliminate infeasible instances, thus avoiding unnecessary computation on parts of these instances. 1.1 Problem Statement and Main Result Let G = (V,E) be a connected, undirected, simple graph with |V| = n. The presented results readily generalize to graphs with multiple connected components (via taking the direct product of the groups from the components. Generalizations to directed graphs and graphs with multiple edges are also straightforward. Let there be a set p ≤n pebbles, numbered 1,..., p, residing on distinct vertices of G. A configuration of these pebbles is an injective map S : {1,..., p} →V. A configuration can also be viewed as a sequence of vertices, S = ⟨s1,...,sp⟩. We use V(S) to denote the range of S. A move is a pair of configurations, ⟨S,S′⟩, such that S,S′ differ at exactly one pebble i and (si,s′ i) ∈E. That is, in a move, a single pebble may migrate from its current vertex to an empty neighboring vertex. When two configurations S and S′ are parts of a move, they are connected. Two configurations S and S′ are also connected (and therefore reachable from each other) if there exists a sequence of configurations ⟨S = S0,...,St = S′⟩such that every pair of consecutive configurations Si,Si+1 in the sequence are connected. The problem of pebble motion on graphs or PMG is defined as follows. 2 Problem 1 (PMG) Given an instance I = (G,S,D) in which G is a connected graph, and S and D are two pebble configurationson G, find a sequence of moves that connects configurations S and D. It is clear that a given PMG instance may not have a solution. If it does, then it is feasible. When G is a tree, PMG is also referred to as pebble motion on trees (PMT). In this case, an instance is usually written as I = (T,S,D). Auletta et al. [1] showed that the feasibility test of a PMT instance can be performed in O(n) operations. We generalize this linear time result to graphs. The main result of the paper is presented in the following theorem. Theorem 2 The feasibility test of PMG can be performed in O(|V|+ |E|) time. The key idea behind our linear time feasibility test is reducing a PMG instance to a PMT-like instance, allowing many ideas from [1] to be adapted for proving Theorem 2. This leads to some intermediate results that look similar to those from [1] but require significantly different proofs. To make this paper self contained, complete proofs are generally provided for these intermediate results. 2 Reducing Pebble Motion on Graphs to Pebble Per- mutation on Graphs If V(S) = V(D) in a PMG instance (G,S,D), D can be viewed as a permutation Π of S, defined as di = sΠ(i) for all i (i.e., Π permutes the pebbles). We call such a problem pebble permutation on graphs, or PPG. The main goal of this section is to show that any PMG instance can be reduced to an equivalent PPG instance such that the |V(S)| pebbles can occupy any set of |V(S)| vertices on G. If the underlying graph is a tree in a PPG instance, the problem becomes pebble permutation on trees, or PPT. Reducing a PMG instance to an equivalent PPG can be done using Theorem 3 from [1], a restatement of which is given below. We give a shorter constructive proof of this result. Theorem 3 Let (T,S,D) be a PMT instance. In O(n) steps, an instance (T,S′,Π) of PPT can be computed such that S,S′ are connected and for all i, di = s′ Π(i) for a fixed permutation Π. PROOF. We produce a mapping between S and a new configuration S′ so that the re- quirements are satisfied. To start, all leaf vertices of T are put into a queue Q and processed in the order they are added. After a vertex v from Q is processed, its neigh- bors, N(v), are examined. If a neighbor u ∈N(v) has not been added to Q, u is added to Q if N(u) has at most one member which has not already been added to Q. It is straightforward to check that adding vertices to Q this way guarantees that Q will not be empty until all vertices of T are processed. The processed vertices form a forest, F, of which the trees eventually combine to yield T. In this proof, v is always assumed to be the current vertex from Q that is being processed and is adjacent to the tree Ti ∈F (this does not prevent v from being adjacent 3 to other trees from F). As v is being processed, Ti will be examined. Depending on how |V(S)∩V(Ti)| and |V(D)∩V(Ti)| compare, there are three possibilities. First, if |V(S) ∩V(Ti)| = |V(D) ∩V(Ti)|, then nothing additional is needed to be done for Ti. Next, if |V(S)∩V(Ti)| > |V(D)∩V(Ti)|, then some pebbles will need to be moved out of Ti through its root so that the numbers of pebbles on Ti from S and D are the same. For such a tree Ti, a surplus queue, Q+ i , of pebbles will be maintained, so that pebbles at the front of the queue are readily moved out of the root of Ti. To maintain Q+ i , the operations for removing and adding a pebble, as well as merging of two queues need to specified (one more operation involving a surplus queue will be introduced in the next paragraph). Removing a pebble from Q+ i is needed when v ∈V(D) and v /∈V(S); a pebble from Q+ i needs to move to v. For this, simply grab the pebble at the end of Q+ i , since that pebble can be the last pebble to leave the current Ti. To add a pebble (needed when v ∈V(S),v /∈V(D)), insert the pebble in the front of Q+ i . Note that it is possible that v ∈(V(S)∩V(D)); in this case the removal is followed by the insertion. If v will be the new root of two trees Ti,Tj and both trees have surplus queues (Q+ i ,Q+ j , respectively), before processing v, merge Q+ i ,Q+ j by attaching Q+ j at the end of Q+ i . This works since pebbles from Q+ i ,Q+ j must all move through v; all pebbles in Q+ i can move through vi first. Same applies if there are three or more trees meeting at v. Finally, if |V(S) ∩V(Ti)| < |V(D) ∩V(Ti)|, pebbles will need to be moved into Ti through its root. A deficit queue Q− i containing vertices of V(D) is maintained in this case. Assuming Q− i is arranged such that the front vertex is close to the root of Ti. The operations for removing, adding, and merging deficit queues mirror those for surplus queues. An extra queue operation needed here is when a deficit queue Q− i needs to be merged with a surplus queue Q+ j ; this can be done simply by filling Q− i from the back with pebbles of Q+ j starting from the front. □ The constructive proof can be easily adapted to yield paths for actually moving the pebbles (note that doing this requires more than linear time). Theorem 3 allows us to reduce a PMG to an equally feasible PPG. Corollary 4 An instance I = (G,S,D) of PMG can be reduced to a PPG instance, I′ = (G,S′,Π), in linear time. PROOF. Given a PMG instance I = (G,S,D), compute in linear time a spanning tree TG of G. From the PMT instance (TG,S,D), compute a equally feasible PPT instance (TG,S′,Π) (via Theorem 3) in which di = s′ Π(i) for all i. I′ = (G,S′,Π) is the desired PPG instance. To see that I and I′ are equally feasible, note that the sequence of con- figurations connecting S,S′ in TG are still present on G. □ Corollary 4 yields another useful corollary, which says that a PPG instance can be converted to an equivalent one such that the pebbles occupy an arbitrary set of vertices. Corollary 5 Let I = (G,S,Π) be an arbitrary PPG instance and let VA be an arbitrary set of |V(S)| vertices of G. Then I can be reduced to a PPG instance, I′ = (G,S′,Π), in linear time, such that V(S′) = VA. 4 PROOF. Let A be an arbitrary configuration of the |V(S)| pebbles with V(A) =VA. From the PMG instance (G,S,A), a PPG instance (G,S′,Π′) can be computed by Corollary 4 such that the PMG instance (G,S,S′) is feasible. Let D be the goal configuration of I (i.e., di = sΠ(i)). Applying the same moves (that take S to S′) to D yields D′ satisfying d′ i = s′ Π(i). Therefore, S′ occupy the same set of vertices as A and (G,S,Π) is feasible if and only if (G,S′,Π) is feasible. □ 3 Partitioning of PPG Instances We now partition a PPG instance I = (G,S,Π) based on the graph G as some cases re- quire relatively simple but special treatment. A maximal 2-edge-connected component (MTEC for short) of G is a 2-edge-connected component of G that is not contained in any other 2-edge-connected component of G. We use nM to denote the number of vertices of all MTECs of G. The MTECs of a graph can be found in O(|V| + |E|) time [6]. The main goal of this section is to solve all PPG instances other than these with nM −2 ≤p ≤n −2. The case of p = n is trivial. For the discussion in this sec- tion, unless otherwise stated, let (G,S,D) be the PMG instance identical to I (that is, di = sΠ(i)). The first special case is when G is the θ0 graph with seven vertices, which is formed by connecting an extra vertex to two vertices of distance 3 on a hexagon [3]. Any PPG instance in which G is the θ0 graph can be solved in constant time since there are only a finite number of possible configurations. The second special case is when G is a cycle. In this case, S and D, as sequences of vertices, induce natural cyclic orderings of the pebbles. This implies that I is fea- sible if and only if si = d(i+k) mod k for some fixed natural number k. The associated computation requires linear time. The third special case is when G is a 2-connected (i.e., non separable) graph that is not a cycle or the θ0 graph. As pointed out in [7], if G is bipartite and p = n −1, all configurations of pebbles fall into two equivalence classes. In each equivalence class, all configurations are connected and two configurations from different configurations classes are not connected. Deciding whether two configurations are connected can be performed in linear time by computing the parity of the two configurations (i.e., treating the configurations as permutations). Continuing on this special case, if G is bipartite and p ≤n −2, or if G is not bipartite and p ≤n −1, then all configurations are connected. We summarize the cases mentioned so far in the following lemma. Lemma 6 Let I = (G,S,Π) be a PPG instance in which G is a 2-connected graph. The feasibility test of I can be performed in linear time. Moreover, I is always feasible if: 1. G is not a cycle and p ≤n −2, or 2. G is not a cycle, not the θ0 graph, and p ≤n −1. If a PPG instance is always feasible, it means that any pair of pebbles can switch locations without affecting other pebbles. In general, when two pebbles can exchange 5 locations without net effects on the locations of other pebbles, they are equivalent with respect to the specific configuration they are associated with. More formally, two peb- bles i, j are equivalent with respect to a configuration S if S is connected to a config- uration S′ in which si = s′ j,sj = s′ i, and sk = s′ k for all k ̸= i, j. A set of pebbles are equivalent if every pair of pebbles from the set are equivalent. It is clear that this type of equivalence is reflexive and transitive. Note that our definition of pebble equivalence equals the definition of vertex equivalence used in [1]. Corollary 7 Let I = (G,S,Π) be an instance of PPG in which G is a single 2-connected component plus a single degree one vertex attached to that component. If p ≤n −2, then I is feasible. PROOF. Let the component be H and the degree one vertex be v. We may assume that in S, v is occupied by a pebble i. If H is a cycle, with two empty vertices on the cycle H, it is straightforward to check that i can be exchanged with any other pebble on H. This implies that all pebbles are equivalent with respect to S. Thus, I is feasible for an arbitrary Π. If H is not a cycle, with pebble i on v, all pebbles on H are equivalent with respect to S by Lemma 6. Fixing any cycle C on H adjacent to v, moving the empty vertices to C shows that pebble i is equivalent to at least one pebble on C. By transitivity, all pebbles are again equivalent with respect to S. □ The fourth special case is when G is 2-edge-connected and separable (i.e., not 2- connected), for which statements similar to that from Lemma 6 can be made. We include all four cases in the following theorem. Theorem 8 Let I = (G,S,Π) be a PPG instance in which G is a 2-edge-connected graph. The feasibility test of I can be performed in linear time. Moreover, I is always feasible if G is not a cycle and p ≤n −2. v1 H v2 i1 i2 H¶ Figure 2: A 2-edge-connectedgraph can be viewed as a tree of its maximal 2-connected components. PROOF. Since the case of G being non separable is covered by Lemma 6, assume that G is separable. G is then two or more 2-connected graphs joined at articulation vertices, forming a tree like structure (see, e.g., Fig. 2). If p ≤n −2, without loss of generality, assume (given configuration S) that there are two empty vertices v1,v2 on a “leaf” 2-connected component H of G. By Corollary 7, the current pebbles on H in S 6 and i1,i2 are all equivalent. Restricting our attention to H′ and v2, all pebbles on H’ are equivalent with respect to S by Corollary 7. By transitivity of pebble equivalence, all pebbles on H,H′ in S are equivalent. Inductively, all pebbles in S are equivalent. If p = n−1, imagine in Fig. 2 that (given configuration S) all vertices other than v1 are occupied. Since no pebbles can cross the border between H,H′, if I|H (I restricted to H in the natural way) is not feasible, then I cannot be feasible. Same applies to I|H′. By shifting the empty vertex to other 2-connected components, additional restricted instances can be obtained. I is feasible if and only if all such restrictions are feasible. Since these instances can be computed independently, observe that the overall time needed is O(|V|+ |E|). □ With Theorem 8, we can state a more useful version of Corollary 7. Corollary 9 Let I = (G,S,Π) be an instance of PPG in which G is a single MTEC with a single degree one vertex attached to the MTEC. If p ≤n −2, then I is feasible. Next, we look at the case of p = n −1 for general graphs. The proof strategy is similar to that used for proving the p = n −1 case of Theorem 8. Theorem 10 The feasibility of a PPG instance in which p = n −1 can be decided in O(|V|+ |E|) time. PROOF. Let I = (G,S,Π) be an instance of PPG in which p = n −1. The claim holds when G is a tree or a 2-edge-connected graph; assume G is not such a graph. Let H be an MTEC of G. Without loss of generality, we may assume that in configuration S, the only unoccupied vertex is within H, leaving |V(H)|−1 pebbles on H. By Theorem 8, the feasibility of I|H can be decided in linear time. If I|H is not feasible, then I itself cannot be feasible. If I|H is feasible, then other MTECs of G are examined next. For this, configurations S is updated to S′such that another MTEC (if any) of G will now have one unoccupied vertex (note that pebbles do not need to be actually moved). Perform the same movements on D gives D′ with the same unoccupied vertex (recall that D is the goal configuration). This yields an equivalent PPG instance I′ = (G,S′,Π). Let the MTEC with the unoccupied vertex be H′, feasibility of I′|H′ can also be checked in linear time. If any I′|H′ is infeasible, then I is infeasible. Checking the feasibility of all such restricted instances take total time O(|V|+ |E|). If I remains feasible after above checks, rest of the pebbles (those that have not appeared in I|H or an I′|H′) must be examined. For each of these pebbles, say pebble i, if si ̸= di, then I is not feasible. Otherwise, I is feasible. □ The last special case is when p ≤nM −3. Theorem 11 A PPG instance is feasible when p ≤nM −3 and G is not a cycle. PROOF. Let I = (G,S,Π) be an arbitrary instance of PPG in which p ≤nM −3. This excludes G from being a tree. If G is a 2-edge-connected graph and not a cycle, then the claim trivially holds by Theorem 8. Same is true if G contains only one MTEC by 7 Corollary 9. For the rest of the proof, assume that G contains two or more MTECs. We only work with configuration S and prove the case p = nM −3. Other cases then trivially follow. By Corollary 5, assume without loss of generality that all p pebbles are on MTECs of G and one MTEC, say H, has at three unoccupied vertices. This means that MTECs other than H are fully occupied. Let H′ be another MTEC such that there are no other MTECs between H and H′. Let ii,i2 be two pebbles on H′ that occupy vertices closest to H. Since there are no pebbles between H and H′, pebbles i1,i2 can be moved such that i1 is on H and i2 is on a vertex adjacent to H (see e.g., Fig. 3). Let the vertex to which i2 is moved be v; note that v may be on H′. Let the new configuration be S′. By Corollary 9, the pebbles current on H plus i2 are all equivalent with respect to S′ and therefore, S. i1 H¶ H v i2 Figure 3: Moving two pebbles between to adjacent MTECs H and H′. The two small dotted circles are the new locations of pebbles i1 (left) and i2 (right). On the other hand, from the configuration S, i1 can be moved away from H′ and i2 can then be moved to a vertex adjacent to H′. This leaves two empty vertices on H′; let this configuration be S′′. Following the same argument, all pebbles on H′ plus i2 are equivalent with respect to S′′ and therefore, S. By transitivity, all pebbles on H,H′ in configuration S are equivalent. Inductively, this shows that all pebbles are equivalent with respect to S. Thus I is feasible. □ 4 Reducing Pebble Permutations to Pebble Exchanges In this section, let I = (G,S,Π) be a PPG instance in which G contains an MTEC, G is not a single MTEC, and p ≤n −2. We show that such an instance is feasible if and only if for all i, pebbles i and Π(i) are equivalent with respect to S. That is, pebbles i and Π(i) can be exchanged without net effects on other pebbles. Lemma 12 Let S be an arbitrary configuration and let i, j be two pebbles. If both i and j can reach two distinct vertices (not necessarily the same two vertices for i, j) of an MTEC H, then i and j are equivalent with respect to S. PROOF. Assume without loss of generality that pebble i first gets to a configuration S′ such that it is on H and can move to a nearby empty vertex on H. Assume that pebble j can do the same in a later configuration S′′ (if both pebbles i, j are already on H with an empty vertex on H, i, j are equivalent by Corollary 9). 8 Starting from S′, if there is only one empty vertex on H, move pebbles outside H such that an vertex adjacent to H is empty (since G is not a single MTEC). This setup satisfies the conditions of Corollary 9. Therefore, all pebbles on H, including i, are equivalent with respect to the current configuration and also S′. Since an MTEC contains at least 3 vertices, i is at least equivalent to one other pebble (note that this pebble may not be on H in configuration S′). From configuration S′, to move j to H, some pebbles may need to be moved to H and some pebbles, including i, may get moved out of H. We now augment the config- urations between S′ and S′′ so that pebble i never leaves H. First note that if i is the only pebble on H and is supposed to leave H, then it must be for some other pebble to move into H. It is straightforward to verify that the next pebble entering H must also be equivalent to i and can take on pebble i’s role. If i is not the only pebble on H and is supposed to leave, again we can let some pebble equivalent to i leave H. With this augmentation, when pebble j eventually gets to H and can move to another vertex of H, i and j are clearly equivalent with respect to the current configuration and therefore, S (exchange i, j and reverse all previous moves). □ For a given G, if a vertex x is an articulation vertex, removing x splits G into two or more components. Denote these components as C(x) (G is assumed). Denote the component from C(x) containing y as C(x,y) and the rest C(x,y). We now give a generalization of Lemma 6 from [1]. Lemma 13 Let S be an arbitrary configuration and suppose that i, j are two pebbles occupying vertices u,v, respectively. Let w be a vertex such that two shortest paths between u,v and v,w share at least one common edge. Suppose that there are moves that take S to a configuration in which i is at v and j is at w. Then i, j are equivalent with respect to S. PROOF. Lemma 6 from [1] shows that Lemma 13 holds when G is a tree. Our proof seeks to reduce our case to the tree case. Note that when G is a tree, the shortest paths between a pair of vertices are unique, which is not the case for a general graph. The statement of Lemma 13 only requires that a shortest path between some u,v and a shortest path between v,w share an edge. Also, pebbles other than i, j can be treated as indistinguishable pebbles; their locations before and after the moves do not matter. Let the sequence of moves that takes i, j to v,w, respectively, be X. For convenience, let u ⇝v and v ⇝w denote two shortest paths that share at least one edge. These paths may not be unique on G. We require that u ⇝v and v ⇝w have only one intersection (which may contain multiple edges and vertices), denoted y ⇝v. u ⇝y and y ⇝w denote the parts of u ⇝v and v ⇝w, respectively, after removing y ⇝v. Note that fixing a u ⇝v, if some vertex z on u ⇝v is on an MTEC then any path that i takes to reach v from u must also reach the same MTEC even if i does not pass z. If u,v belong to the same MTEC H, any u ⇝v, as a shortest path, must fall entirely in H. This suggests that i and j can both reach two vertices of H. i, j are equivalent by Lemma 12. Assume for the rest of the proof that u,v do not belong to the same MTEC. If any edge e in y ⇝v appear in an MTEC H, then i, j must visit at least two vertices of H (not necessarily passing edge e) and must be equivalent. We may then assume 9 that y ⇝v has no edges belonging to an MTEC of G. Furthermore, we may assume that no vertices on y ⇝v (including y but not v) belong to any MTEC H; otherwise i, j must be equivalent. To see this, assume without loss of generality that y is on some MTEC H. At some point, i must pass through H. If i travels through an edge of H, we return to the earlier case; suppose not. This forces i to pass H through y. When i has just arrived at y, there is an empty vertex on u ⇝y and there must also be an empty vertex in C(y,u). These two empty vertices allow i to reach at least one more vertex of H other than y. Same applies to j, making i, j equivalent with respect to S by Lemma 12. H y v w u x u¶ w¶ v¶ Figure 4: If i, j (on u,v, respectively) can reach v,w, then a pebble equivalent to i can reach v without using features of MTEC as j moves to w . We now look at u ⇝y. If any vertex inside u ⇝y (i.e., excluding u,y) belong to some MTEC, let the H be such an MTEC that is closest to y (H may not be unique). Since i can reach H, it can reach two vertices of H (by the argument in the previous paragraph). Pebble i can then take take any position on H. Let x be the vertex of H that is closest to y (this vertex is unique), we may assume that i is initially located on a vertex u′ on H adjacent to x (see e.g., Fig. 4). Using the argument in the proof of Lemma 12, X can be modified so that i never needs to move to vertices other than u′ in C(x,y). This means that we can effectively treat x as a T-junction instead of a vertex of an MTEC for moving i, j to v,w, respectively. If no vertices inside u ⇝y is on an MTEC, it is possible that X requires that i to travel in the opposite direction of u ⇝y, further away from u. Same argument shows that a similar u′ exists (e.g., v′ in Fig. 4). Following the same argument, v′,w′ can be defined similarly so that X can be mod- ified to take i from u′ to v and j from v to w′, without i, j ever reaching two vertices of any MTEC other than u′,v′, and w′. Since no features of MTECs are used, we return to the tree case and i, j are equivalent. □ With Lemma 13, Corollaries 1 and 2 from [1] can be extended to general graphs. We only need the extended version of Corollary 1, stated and proved below. Corollary 14 Let I = (G,S,Π) be a feasible PPG instance. Then there exists 1 ≤i ≤p, such that pebbles i and Π(i) are equivalent with respect to S. PROOF. Applying the proof of Corollary 1 from [1] to a spanning tree of G. □ 10 The main result of this section is an extension of Theorem 4 in [1] to general graphs. We provide a shorter proof enabled by the transitivity of pebble equivalence. Theorem 15 Let I = (G,S,Π) be a feasible PPG instance. Then for all 1 ≤i ≤p, pebbles i and Π(i) are equivalent with respect to S. PROOF. After one application of Corollary 14, at least one pebble can be moved to its desired goal vertex (assuming that Π is not the identity permutation). Repeated applications of pebble exchanges will eventually move pebble i to vertex sΠ(i). By transitivity of pebble equivalence, i can be exchanged with a pebble occupying sΠ(i) at some point. Similarly, any pebble exchanged to occupy sΠ(i) at any point must be equivalent to Π(i). Thus, i and Π(i) are equivalent with respect to S. □ An implication of Theorem 15 is that to test the feasibility of a PPG instance, I = (G,S,Π), we may work with S and Π separately by first computing pebble equivalence classes with respect to S. Two pebbles are put into the same class if and only if they are equivalent with respect to S. The instance I is feasible if and only if pebbles i and Π(i) belong to the same equivalence class by Theorem 15. 5 Linear Feasibility Test of Pebble Exchanges In this section, we reduce the feasibility test of pebble exchanges on general graphs to the feasibility test of pebble exchanges on trees in linear time. The linear time algorithm from [1] then applies. The key lemma enabling this reduction is as follows. Lemma 16 Let I = (G,S,Π) be a PPG instance in which p ≤n−2 and G contains an MTEC H with one empty vertex. Contract H into a single edge (v1,v2) such that all vertices adjacent to H are now adjacent to v1. Let this new graph be G′. All pebbles already on H are treated as a single pebble (equivalence class) staying on v2, leaving v1 empty. Then the pebble equivalence classes on G with respect to S is the same as the pebble equivalence classes computed on G′. PROOF. We need to show that movements of pebbles can be done with H if and only if equivalent movements can also be done using the new structure. Call the single pebble that represents the |V(H)|−1 pebbles the composite pebble. First, note that it is never necessary to have more than two empty vertices on H in any planned moves of pebbles. To see this, suppose at some point more than two vertices of H are to be emptied. The reason for doing this can only be to allow other pebbles to move into or through H. However, with two empty vertices on H, both objectives can already be achieved. To move a pebble i through H, with two empty vertices, i can enter H, leaving one empty vertex on H. This empty vertex then allows i to move to any desired exit. Next, observe that the only reason to fill H with pebbles is when a pebble need to “pass by” H (i.e., the pebble enters and leaves H without visiting other vertices of H). To see this, suppose a pebble i enters H, making H fully occupied. If i is to move to 11 other vertices of H, then some other vertices of H must be emptied first, which can be done before i enters H. We may now assume that the planned moves never move more than two vertices out of H and H is never full unless a pebble is to pass through v1. This leaves three possible operations involving H: 1. Moving out a pebble from H, leaving |V(H)| −2 pebbles on H, 2. Moving a pebble into H when there are |V(H)|−2 pebbles on H, and 3. Moving a pebble through H (not a “pass by”). For the first case, with |V(H)|−1 pebbles on H, any pebble i on H can be moved to a desired exit. Note that this requires a vertex adjacent to H, say v, to be empty. To carry out the same operation on the edge (v1,v2), we empty the composite pebble from v2 to v1 and let it represent pebble i (other pebbles represented by the composite pebble stay at v2 and are “invisible”). i can then be moved to v as well. It is clear that the only if part is also true. The second case is the reverse of the first case. For the third case, suppose we want to move a pebble i from a vertex u adjacent to H to a vertex v, also adjacent to H. For this to be doable through H, there must be at least two empty vertices between H and v. Without loss of generality, assume that H has one empty vertex. With two empty vertices between H and v, we first move a pebble, say j, from H to v. The two vertices allows i to be exchanged with a pebble k on H. k now occupies u. This again leaves two empty vertices on H, allowing i to exchange with j on v. The |V(H)−1| pebbles on H can then be returned to their initial configuration by Corollary 9. The same operation is straightforward to carry out on (v1,v2) and u,v: With two empty vertices, v2 and v can be emptied, allowing i to move to v directly. □ For a MTEC H that is fully occupied, it is also converted as outlined in the above lemma. The only difference is that a pebble now needs to be put on v1. This pebble cannot always be arbitrarily selected from the pebbles on H. Since there are at least two empty vertices somewhere on G, at least two pebbles can be moved out of H. If there are two vertices adjacent to H that can be emptied (without moving pebbles on H), then all pebbles on H are equivalent (with respect to the current configuration) by Corollary 9. To shrink H in this case, an arbitrary pebble on H can be selected to occupy v1 and the other |V(H)| −1 are combined into a composite pebble that occupies v2. On the other hand, if only one vertex adjacent to H, say v, can be emptied, the pebble occupying the vertex of H adjacent to v may not be equivalent to the rest |V(H)| −1 pebbles. The |V(H)|−1 pebbles, however, are equivalent by Corollary 9. In this later case, we let this not necessarily equivalent pebble occupy v1 (in the shrunk graph G′) and combine the rest into a composite pebble occupying v2. The equivalence between H and the converted edge can be formally proven using the same proof from Lemma 16 (need to add a case that moves the pebble on v1 away before any other operations). A reduction example is given in Fig. 5. Lemma 17 Let I = (G,S,Π) be a PPG instance in which nM −2 ≤p ≤n −2. The feasibility of I can be decided in time O(|V|+ |E|). PROOF. The case of G being a tree or a single MTEC is already covered. If G contains a single MTEC and p = nM −2, then I is feasible by Corollary 9. 12 For the rest of the cases, by Corollary 5, we may assume that in configuration S, any MTEC H is occupied by at least |V(H)| −1 pebbles. Using the reduction from Lemma 16 (and the comments that follow), all MTECs can be converted into single edges (with the associated pebbles combined), yielding a tree in the end. From this we can obtain a PPT instance. Grouping pebbles into equivalence classes for this PPT instance can be performed in linear time using the algorithm from [1]. □ Figure 5: A graph with three MTECs (top) and the converted tree (bottom). Combining Lemma 17 with the results (i.e., p ≤nM −3 or p ≥n−1) from Section 3 yields the main result (Theorem 2) of this paper. References [1] V. Auletta, A. Monti, M. Parente, and P. Persiano. A linear-time algorithm for the feasbility of pebble motion on trees. Algorithmica, 23:223–245, 1999. [2] G. Goraly and R. Hassin. Multi-color pebble motion on graph. Algorithmica, 58:610–636, 2010. [3] D. Kornhauser, G. Miller, and P. Spirakis. Coordinating pebble motion on graphs, the diameter of permutation groups, and applications. In Proceedings of the 25th Annual Symposium on Foundations of Computer Science (FOCS ’84), pages 241– 250, 1984. [4] S. Loyd. Mathematical Puzzles of Sam Loyd. Dover, New York, 1959. [5] E. W. Story. Note on the ‘15’ puzzle. American Journal of Mathematics, 2:399– 404, 1879. 13 [6] R. E. Tarjan. Depth-first search and linear graph algorithms. SIAM Journal on Computing, 1(2):140–160, 1972. [7] R. M. Wilson. Graph puzzles, homotopy, and the alternating group. Journal of Combinatorial Theory (B), 16:86–96, 1974. 14