Fast algorithms for computing tree lcs Academic Article uri icon


  • The LCS of two rooted, ordered, and labeled trees F and G is the largest forest that can be obtained from both trees by deleting nodes. We present algorithms for computing tree LCS which exploit the sparsity inherent to the tree LCS problem. Assuming G is smaller than F, our first algorithm runs in time O(rheight(F) height(G)lglg|G|)O(r\cdot {\rm height}(F) \cdot {\rm height}(G)\cdot \lg\lg |G|) , where r is the number of pairs (v ∈ F, w ∈ G) such that v and w have the same label. Our second algorithm runs in time O(L r lgr lglg|G|)O(L r \lg r \cdot \lg\lg|G|) , where L is the size of the LCS of F and G. For this algorithm we present a novel three dimensional alignment graph. Our third algorithm is intended for the constrained variant of the problem in which only nodes with zero or one children can be deleted. For this case we obtain an O(r h lglg|G|)O(r h \lg \lg|G|) time algorithm, where h = height(F) + height(G).

publication date

  • June 18, 2008