Affiliation:
1. National University of Singapore, Singapore
Abstract
In the tortoise-and-hare algorithm, when the fast pointer reaches the end of a finite list, the slow pointer points to the middle of this list. In the early 2000’s, this property was found to make it possible to program a palindrome detector for immutable lists that operates in one recursive traversal of the given list and performs the smallest possible number of comparisons, using the “There And Back Again” (TABA) recursion pattern. In this article, this palindrome detector is reconstructed in OCaml, formalized with the Coq Proof Assistant, and proved to be correct. More broadly, this article presents a compositional account of the tortoise-and-hare algorithm for finite lists. Concretely, compositionality means that programs that use a fast and a slow pointer can be expressed with an ordinary fold function for lists and reasoned about using ordinary structural induction on the given list. This article also contains a dozen new applications of the TABA recursion pattern and of its tail-recursive variant, “There and Forth Again”.
Publisher
Association for Computing Machinery (ACM)
Reference44 articles.
1. Collapsing towers of interpreters
2. Josh Berdine. 2004. Linear and Affine Typing of Continuation-Passing Style. Ph. D. Dissertation. Queen Mary, University of London.
3. Using circular programs to eliminate multiple traversals of data