Finding and counting permutations via CSPs

From MaRDI portal
Publication:6323601

DOI10.1007/S00453-021-00812-ZarXiv1908.04673MaRDI QIDQ6323601FDOQ6323601


Authors: Benjamin Aram Berendsohn, László Kozma, Dániel Marx Edit this on Wikidata


Publication date: 13 August 2019

Abstract: Permutation patterns and pattern avoidance have been intensively studied in combinatorics and computer science, going back at least to the seminal work of Knuth on stack-sorting (1968). Perhaps the most natural algorithmic question in this area is deciding whether a given permutation of length n contains a given pattern of length k. In this work we give two new algorithms for this well-studied problem, one whose running time is nk/4+o(k), and a polynomial-space algorithm whose running time is the better of O(1.6181n) and O(nk/2+1). These results improve the earlier best bounds of n0.47k+o(k) and O(1.79n) due to Ahal and Rabinovich (2000) resp. Bruner and Lackner (2012) and are the fastest algorithms for the problem when kinOmega(logn). We show that both our new algorithms and the previous exponential-time algorithms in the literature can be viewed through the unifying lens of constraint-satisfaction. Our algorithms can also count, within the same running time, the number of occurrences of a pattern. We show that this result is close to optimal: solving the counting problem in time f(k)cdotno(k/logk) would contradict the exponential-time hypothesis (ETH). For some special classes of patterns we obtain improved running times. We further prove that 3-increasing and 3-decreasing permutations can, in some sense, embed arbitrary permutations of almost linear length, which indicates that an algorithm with sub-exponential running time is unlikely, even for patterns from these restricted classes.













This page was built for publication: Finding and counting permutations via CSPs

Report a bug (only for logged in users!)Click here to report a bug for this page (MaRDI item Q6323601)