Selection from read-only memory with limited workspace.

Theoretical Computer Science(2014)

引用 25|浏览32
暂无评分
摘要
Given an unordered array of N elements drawn from a totally ordered set and an integer k in the range from 1 to N, in the classic selection problem the task is to find the k-th smallest element in the array. We study the complexity of this problem in the space-restricted random-access model: The input array is stored on read-only memory, and the algorithm has access to a limited amount of workspace. We prove that the linear-time prune-and-search algorithm—presented in most textbooks on algorithms—can be modified to use Θ(N) bits instead of Θ(N) words of extra space. Prior to our work, the best known algorithm by Frederickson could perform the task with Θ(N) bits of extra space in O(Nlg⁎⁡N) time. Our result separates the space-restricted random-access model and the multi-pass streaming model, since we can surpass the Ω(Nlg⁎⁡N) lower bound known for the latter model. We also generalize our algorithm for the case when the size of the workspace is O(S) bits, where lg3⁡N≤S≤N. The running time of our generalized algorithm is O(Nlg⁎⁡(N/S)+N(lg⁡N)/lg⁡S), slightly improving over the O(Nlg⁎⁡(N(lg⁡N)/S)+N(lg⁡N)/lg⁡S) bound of Frederickson's algorithm. To obtain the improvements mentioned above, we developed a new data structure, called the wavelet stack, that we use for repeated pruning. We expect the wavelet stack to be a useful tool in other applications as well.
更多
查看译文
关键词
Selection algorithm,Read-only memory,Random-access machine,Multi-pass streaming,Bit vector,Wavelet stack
AI 理解论文
溯源树
样例
生成溯源树,研究论文发展脉络
Chat Paper
正在生成论文摘要