In this article, we provide new structural results and algorithms for the Homotopy Height problem. In broad terms, this problem quantifies how much a curve on a surface needs to be stretched to sweep continuously between two positions. More precisely, given two homotopic curves γ 1 and γ 2 on a combinatorial (say, triangulated) surface, we investigate the problem of computing a homotopy between γ 1 and γ 2 where the length of the longest intermediate curve is minimized. Such optimal homotopies are relevant for a wide range of purposes, from very theoretical questions in quantitative homotopy theory to more practical applications such as similarity measures on meshes and graph searching problems.We prove that Homotopy Height is in the complexity class NP, and the corresponding exponential algorithm is the best one known for this problem. This result builds on a structural theorem on monotonicity of optimal homotopies, which is proved in a companion paper. Then we show that this problem encompasses the Homotopic Fréchet distance problem which we therefore also establish to be in NP, answering a question which has previously been considered in several different settings. We also provide an O(log n)-approximation algorithm for Homotopy Height on surfaces by adapting an earlier algorithm of Har-Peled, Nayyeri, Salvatipour and Sidiropoulos in the planar setting.1 Introduction This paper considers computational questions pertaining to homotopies: in broad terms, a homotopy between two curves in a topological space is a continuous deformation between these two curves. This can be formalized either in a continuous setting, where it constitutes one of the fundamental constructs of algebraic topology, but also in a more discrete one, where the input is a simplicial, or more generally cellular description of a topological space; this latter setting will be the focus of this article. While considerably more restrictive than the more traditional mathematical settings, this setting