{"title":"Algorithms for Subpath Convex Hull Queries and Ray-Shooting among Segments","authors":"Haitao Wang","doi":"10.1137/21m145118x","DOIUrl":null,"url":null,"abstract":"SIAM Journal on Computing, Volume 53, Issue 4, Page 1132-1161, August 2024. <br/> Abstract. In this paper, we first consider the subpath convex hull query problem: Given a simple path [math] of [math] vertices, preprocess it so that the convex hull of any query subpath of [math] can be quickly obtained. Previously, Guibas, Hershberger, and Snoeyink [Int. J. Comput. Geom. Appl., 1 (1991), pp. 1–22; first appeared in SODA 1990] proposed a data structure of [math] space and [math] query time; they also reduced the query time to [math] by increasing the space to [math]. We present an improved result that uses [math] space while achieving [math] query time. Like the previous work, our query algorithm returns a compact interval tree representing the convex hull so that standard binary-search-based queries on the hull can be performed in [math] time each. The preprocessing time of our data structure is [math] after the vertices of [math] are sorted by [math]-coordinate. As the subpath convex hull query problem has many applications, our new result leads to improvements for several other problems. In particular, with the help of the above result, along with other techniques, we present new algorithms for the ray-shooting problem among segments. Given a set of [math] (possibly intersecting) line segments in the plane, preprocess it so that the first segment hit by a query ray can be quickly found. We give a data structure of [math] space that can answer each query in [math] time. If the segments are nonintersecting or if the segments are lines, then the space can be reduced to [math]. As a by-product, given a set of [math] (possibly intersecting) segments in the plane, we build a data structure of [math] space that can determine whether a query line intersects a segment in [math] time. The preprocessing time is [math] for all four problems, which can be reduced to [math] time by a randomized algorithm so that the query time is bounded by [math] with high probability. All these are classical problems that have been studied extensively. Previously data structures of [math] query time were known in the early 1990s (the notation [math] suppresses a polylogarithmic factor); nearly no progress has been made for more than two decades. For all these problems, our new results provide improvements by reducing the space of the data structures by at least a logarithmic factor while the preprocessing and query times are the same as before or even better.","PeriodicalId":49532,"journal":{"name":"SIAM Journal on Computing","volume":"60 1","pages":""},"PeriodicalIF":1.2000,"publicationDate":"2024-08-13","publicationTypes":"Journal Article","fieldsOfStudy":null,"isOpenAccess":false,"openAccessPdf":"","citationCount":"0","resultStr":null,"platform":"Semanticscholar","paperid":null,"PeriodicalName":"SIAM Journal on Computing","FirstCategoryId":"94","ListUrlMain":"https://doi.org/10.1137/21m145118x","RegionNum":3,"RegionCategory":"计算机科学","ArticlePicture":[],"TitleCN":null,"AbstractTextCN":null,"PMCID":null,"EPubDate":"","PubModel":"","JCR":"Q3","JCRName":"COMPUTER SCIENCE, THEORY & METHODS","Score":null,"Total":0}
引用次数: 0
Abstract
SIAM Journal on Computing, Volume 53, Issue 4, Page 1132-1161, August 2024. Abstract. In this paper, we first consider the subpath convex hull query problem: Given a simple path [math] of [math] vertices, preprocess it so that the convex hull of any query subpath of [math] can be quickly obtained. Previously, Guibas, Hershberger, and Snoeyink [Int. J. Comput. Geom. Appl., 1 (1991), pp. 1–22; first appeared in SODA 1990] proposed a data structure of [math] space and [math] query time; they also reduced the query time to [math] by increasing the space to [math]. We present an improved result that uses [math] space while achieving [math] query time. Like the previous work, our query algorithm returns a compact interval tree representing the convex hull so that standard binary-search-based queries on the hull can be performed in [math] time each. The preprocessing time of our data structure is [math] after the vertices of [math] are sorted by [math]-coordinate. As the subpath convex hull query problem has many applications, our new result leads to improvements for several other problems. In particular, with the help of the above result, along with other techniques, we present new algorithms for the ray-shooting problem among segments. Given a set of [math] (possibly intersecting) line segments in the plane, preprocess it so that the first segment hit by a query ray can be quickly found. We give a data structure of [math] space that can answer each query in [math] time. If the segments are nonintersecting or if the segments are lines, then the space can be reduced to [math]. As a by-product, given a set of [math] (possibly intersecting) segments in the plane, we build a data structure of [math] space that can determine whether a query line intersects a segment in [math] time. The preprocessing time is [math] for all four problems, which can be reduced to [math] time by a randomized algorithm so that the query time is bounded by [math] with high probability. All these are classical problems that have been studied extensively. Previously data structures of [math] query time were known in the early 1990s (the notation [math] suppresses a polylogarithmic factor); nearly no progress has been made for more than two decades. For all these problems, our new results provide improvements by reducing the space of the data structures by at least a logarithmic factor while the preprocessing and query times are the same as before or even better.
期刊介绍:
The SIAM Journal on Computing aims to provide coverage of the most significant work going on in the mathematical and formal aspects of computer science and nonnumerical computing. Submissions must be clearly written and make a significant technical contribution. Topics include but are not limited to analysis and design of algorithms, algorithmic game theory, data structures, computational complexity, computational algebra, computational aspects of combinatorics and graph theory, computational biology, computational geometry, computational robotics, the mathematical aspects of programming languages, artificial intelligence, computational learning, databases, information retrieval, cryptography, networks, distributed computing, parallel algorithms, and computer architecture.