4.1 Article

Space Efficient Linear Time Algorithms for BFS, DFS and Applications

期刊

THEORY OF COMPUTING SYSTEMS
卷 62, 期 8, 页码 1736-1762

出版社

SPRINGER
DOI: 10.1007/s00224-017-9841-2

关键词

Space efficient algorithms; DFS; BFS; Succinct dictionary; Topological sort; Biconnectivity; Chain decomposition

向作者/读者索取更多资源

Research on space efficient graph algorithms, particularly for stconnectivity, has a long history including the celebrated polynomial time, O( lg n) bits1 algorithm in undirected graphs by Reingold J. JACM. 55( 4) ( 2008), and polynomial time, n/ 2 ( v lg n) bits algorithm in directed graphs by Barnes et al. SICOMP. 27( 5), 1273- 1282 ( 1998). Recent works by Asano et al. ISAAC ( 2014) and Elmasry et al. STACS ( 2015), reconsidered classical fundamental graph algorithms focusing on improving the space complexity. Elmasry et al. gave, among others, an implementation of breadth first search ( BFS) in a graph G with n vertices and m edges, taking the optimal O( m+ n) time using O( n) bits improving the na ive O( n lg n) bits implementation. Similarly, Asano et al. provided space efficient implementations for performing depth first search (DFS) in a graph G. We continue this line of work focusing on improving the space requirement for implementing a few classical graph algorithms. Our first result is a simple data structure that can maintain any subset S of a universe of u elements using just u + o(u) bits and supports in constant time, apart from the standard insert, delete and membership queries, the operation findany that finds and returns any element of the set (or outputs that the set is empty). It can also enumerate all elements present currently in the set in no particular order in O(k + 1) time where k is the number of elements currently belonging to the set. While this data structure supports a weaker set of operations than that of Elmasry et al. STACS (2015), it is simple, more space efficient and is sufficient to support a BFS implementation optimally in O(m+ n) time using at most 2n+ o(n) bits. Later, we further improve the space requirement of BFS to at most n lg 3+ o(n) bits albeit with a slight increase in running time to O(mlg nf (n)) time where f (n) is any extremely slow growing function of n, and the o term in the space is a function of f (n). We also discuss a similar time- space tradeoff result for finding a minimum weight spanning tree of a weighted (bounded by polynomial in n) undirected graph using n + O(n/ f (n)) bits and O(mlg nf (n)) time, for any function f (n) such that 1 = f (n) = n. ForDFS in a graph G, we provide an implementation taking O(m+ n) time and O(n lg m/ n) bits. This partially answers at least for sparse graphs, a question asked by Asano et al. ISAAC (2014) whether DFS can be performed in O(m+ n) time and using O(n) bits, and also simultaneously improves the DFS result of Elmasry et al. STACS (2015). Using our DFS algorithm and other careful implementations, we show how one can also test for biconnectivity, 2- edge connectivity, and find cut vertices and bridges of a given undirected graph within the same time and space bounds; earlier classical linear time algorithms for these problems used (n lg n) bits of space.

作者

我是这篇论文的作者
点击您的名字以认领此论文并将其添加到您的个人资料中。

评论

主要评分

4.1
评分不足

次要评分

新颖性
-
重要性
-
科学严谨性
-
评价这篇论文

推荐

暂无数据
暂无数据