Dynamic Graph Algorithms
Total Page:16
File Type:pdf, Size:1020Kb
Load more
										Recommended publications
									
								- 
												  Strongly Connected ComponentGraph IV Ian Things that we would talk about ● DFS ● Tree ● Connectivity Useful website http://codeforces.com/blog/entry/16221 Recommended Practice Sites ● HKOJ ● Codeforces ● Topcoder ● Csacademy ● Atcoder ● USACO ● COCI Term in Directed Tree ● Consider node 4 – Node 2 is its parent – Node 1, 2 is its ancestors – Node 5 is its sibling – Node 6 is its child – Node 6, 7, 8 is its descendants ● Node 1 is the root DFS Forest ● When we do DFS on a graph, we would obtain a DFS forest. Noted that the graph is not necessarily a tree. ● Some of the information we get through the DFS is actually very useful, such as – Starting time of a node – Finishing time of a node – Parent of the node Some Tricks Using DFS Order ● Suppose vertex v is ancestor(not only parent) of u – Starting time of v < starting time of u – Finishing time of v > starting time of u ● st[v] < st[u] <= ft[u] < ft[v] ● O(1) to check if ancestor or not ● Flatten the tree to store subtree information(maybe using segment tree or other data structure to maintain) ● Super useful !!!!!!!!!! Partial Sum on Tree ● Given queries, each time increase all node from node v to node u by 1 ● Assume node v is ancestor of node u ● sum[u]++, sum[par[v]]-- ● Run dfs in root dfs(v) for all child u dfs(u) d[v] = d[v] + d[u] Types of Edges ● Tree edges – Edges that forms a tree ● Forward edges – Edges that go from a node to its descendants but itself is not a tree edge.
- 
												  CLRS B.4 Graph Theory Definitions Unit 1: DFS Informally, a GraphCLRS B.4 Graph Theory Definitions Unit 1: DFS informally, a graph consists of “vertices” joined together by “edges,” e.g.,: example graph G0: 1 ···················•······························· ····························· ····························· ························· ···· ···· ························· ························· ···· ···· ························· ························· ···· ···· ························· ························· ···· ···· ························· ············· ···· ···· ·············· 2•···· ···· ···· ··· •· 3 ···· ···· ···· ···· ···· ··· ···· ···· ···· ···· ···· ···· ···· ···· ···· ···· ······· ······· ······· ······· ···· ···· ···· ··· ···· ···· ···· ···· ···· ··· ···· ···· ···· ···· ···· ···· ···· ···· ···· ···· ··············· ···· ···· ··············· 4•························· ···· ···· ························· • 5 ························· ···· ···· ························· ························· ···· ···· ························· ························· ···· ···· ························· ····························· ····························· ···················•································ 6 formally a graph is a pair (V, E) where V is a finite set of elements, called vertices E is a finite set of pairs of vertices, called edges if H is a graph, we can denote its vertex & edge sets as V (H) & E(H) respectively if the pairs of E are unordered, the graph is undirected if the pairs of E are ordered the graph is directed, or a digraph two vertices joined by an edge
- 
												  Graph Theory1 Graph Theory “Begin at the beginning,” the King said, gravely, “and go on till you come to the end; then stop.” — Lewis Carroll, Alice in Wonderland The Pregolya River passes through a city once known as K¨onigsberg. In the 1700s seven bridges were situated across this river in a manner similar to what you see in Figure 1.1. The city’s residents enjoyed strolling on these bridges, but, as hard as they tried, no residentof the city was ever able to walk a route that crossed each of these bridges exactly once. The Swiss mathematician Leonhard Euler learned of this frustrating phenomenon, and in 1736 he wrote an article [98] about it. His work on the “K¨onigsberg Bridge Problem” is considered by many to be the beginning of the field of graph theory. FIGURE 1.1. The bridges in K¨onigsberg. J.M. Harris et al., Combinatorics and Graph Theory , DOI: 10.1007/978-0-387-79711-3 1, °c Springer Science+Business Media, LLC 2008 2 1. Graph Theory At first, the usefulness of Euler’s ideas and of “graph theory” itself was found only in solving puzzles and in analyzing games and other recreations. In the mid 1800s, however, people began to realize that graphs could be used to model many things that were of interest in society. For instance, the “Four Color Map Conjec- ture,” introduced by DeMorgan in 1852, was a famous problem that was seem- ingly unrelated to graph theory. The conjecture stated that four is the maximum number of colors required to color any map where bordering regions are colored differently.
- 
												  Vizing's Theorem and Edge-Chromatic GraphVIZING'S THEOREM AND EDGE-CHROMATIC GRAPH THEORY ROBERT GREEN Abstract. This paper is an expository piece on edge-chromatic graph theory. The central theorem in this subject is that of Vizing. We shall then explore the properties of graphs where Vizing's upper bound on the chromatic index is tight, and graphs where the lower bound is tight. Finally, we will look at a few generalizations of Vizing's Theorem, as well as some related conjectures. Contents 1. Introduction & Some Basic Definitions 1 2. Vizing's Theorem 2 3. General Properties of Class One and Class Two Graphs 3 4. The Petersen Graph and Other Snarks 4 5. Generalizations and Conjectures Regarding Vizing's Theorem 6 Acknowledgments 8 References 8 1. Introduction & Some Basic Definitions Definition 1.1. An edge colouring of a graph G = (V; E) is a map C : E ! S, where S is a set of colours, such that for all e; f 2 E, if e and f share a vertex, then C(e) 6= C(f). Definition 1.2. The chromatic index of a graph χ0(G) is the minimum number of colours needed for a proper colouring of G. Definition 1.3. The degree of a vertex v, denoted by d(v), is the number of edges of G which have v as a vertex. The maximum degree of a graph is denoted by ∆(G) and the minimum degree of a graph is denoted by δ(G). Vizing's Theorem is the central theorem of edge-chromatic graph theory, since it provides an upper and lower bound for the chromatic index χ0(G) of any graph G.
- 
												  Superposition and Constructions of Graphs Without Nowhere-Zero K-flowsView metadata, citation and similar papers at core.ac.uk brought to you by CORE provided by Elsevier - Publisher Connector Europ. J. Combinatorics (2002) 23, 281–306 doi:10.1006/eujc.2001.0563 Available online at http://www.idealibrary.com on Superposition and Constructions of Graphs Without Nowhere-zero k-flows M ARTIN KOCHOL Using multi-terminal networks we build methods on constructing graphs without nowhere-zero group- and integer-valued flows. In this way we unify known constructions of snarks (nontrivial cubic graphs without edge-3-colorings, or equivalently, without nowhere-zero 4-flows) and provide new ones in the same process. Our methods also imply new complexity results about nowhere-zero flows in graphs and state equivalences of Tutte’s 3- and 5-flow conjectures with formally weaker statements. c 2002 Elsevier Science Ltd. All rights reserved. 1. INTRODUCTION Nowhere-zero flows in graphs have been introduced by Tutte [38–40]. Primarily he showed that a planar graph is face-k-colorable if and only if it admits a nowhere-zero k-flow (its edges can be oriented and assigned values ±1,..., ±(k − 1) so that the sum of the incoming values equals the sum of the outcoming ones for every vertex of the graph). Tutte also proved the classical equivalence result that a graph admits a nowhere-zero k-flow if and only if it admits a flow whose values are the nonzero elements of a finite abelian group of order k. Seymour [35] has proved that every bridgeless graph admits a nowhere-zero 6-flow, thereby improving the 8-flow theorem of Jaeger [16] and Kilpatrick [20].
- 
												  Finding Articulation Points and Bridges Articulation Points Articulation PointFinding Articulation Points and Bridges Articulation Points Articulation Point Articulation Point A vertex v is an articulation point (also called cut vertex) if removing v increases the number of connected components. A graph with two articulation points. 3 / 1 Articulation Points Given I An undirected, connected graph G = (V; E) I A DFS-tree T with the root r Lemma A DFS on an undirected graph does not produce any cross edges. Conclusion I If a descendant u of a vertex v is adjacent to a vertex w, then w is a descendant or ancestor of v. 4 / 1 Removing a Vertex v Assume, we remove a vertex v 6= r from the graph. Case 1: v is an articulation point. I There is a descendant u of v which is no longer reachable from r. I Thus, there is no edge from the tree containing u to the tree containing r. Case 2: v is not an articulation point. I All descendants of v are still reachable from r. I Thus, for each descendant u, there is an edge connecting the tree containing u with the tree containing r. 5 / 1 Removing a Vertex v Problem I v might have multiple subtrees, some adjacent to ancestors of v, and some not adjacent. Observation I A subtree is not split further (we only remove v). Theorem A vertex v is articulation point if and only if v has a child u such that neither u nor any of u's descendants are adjacent to an ancestor of v. Question I How do we determine this efficiently for all vertices? 6 / 1 Detecting Descendant-Ancestor Adjacency Lowpoint The lowpoint low(v) of a vertex v is the lowest depth of a vertex which is adjacent to v or a descendant of v.
- 
												  Dominator Tree Certification and Independent Spanning TreesDominator Tree Certification and Independent Spanning Trees∗ Loukas Georgiadis1 Robert E. Tarjan2 October 29, 2018 Abstract How does one verify that the output of a complicated program is correct? One can formally prove that the program is correct, but this may be beyond the power of existing methods. Alternatively one can check that the output produced for a particular input satisfies the desired input-output relation, by running a checker on the input-output pair. Then one only needs to prove the correctness of the checker. But for some problems even such a checker may be too complicated to formally verify. There is a third alternative: augment the original program to produce not only an output but also a correctness certificate, with the property that a very simple program (whose correctness is easy to prove) can use the certificate to verify that the input-output pair satisfies the desired input-output relation. We consider the following important instance of this general question: How does one verify that the dominator tree of a flow graph is correct? Existing fast algorithms for finding dominators are complicated, and even verifying the correctness of a dominator tree in the absence of additional information seems complicated. We define a correctness certificate for a dominator tree, show how to use it to easily verify the correctness of the tree, and show how to augment fast dominator-finding algorithms so that they produce a correctness certificate. We also relate the dominator certificate problem to the problem of finding independent spanning trees in a flow graph, and we develop algorithms to find such trees.
- 
												  Maker-Breaker Total Domination Game Valentin Gledel, Michael AMaker-Breaker total domination game Valentin Gledel, Michael A. Henning, Vesna Iršič, Sandi Klavžar To cite this version: Valentin Gledel, Michael A. Henning, Vesna Iršič, Sandi Klavžar. Maker-Breaker total domination game. 2019. hal-02021678 HAL Id: hal-02021678 https://hal.archives-ouvertes.fr/hal-02021678 Preprint submitted on 16 Feb 2019 HAL is a multi-disciplinary open access L’archive ouverte pluridisciplinaire HAL, est archive for the deposit and dissemination of sci- destinée au dépôt et à la diffusion de documents entific research documents, whether they are pub- scientifiques de niveau recherche, publiés ou non, lished or not. The documents may come from émanant des établissements d’enseignement et de teaching and research institutions in France or recherche français ou étrangers, des laboratoires abroad, or from public or private research centers. publics ou privés. Maker-Breaker total domination game Valentin Gledel a Michael A. Henning b Vesna Irˇsiˇc c;d Sandi Klavˇzar c;d;e January 31, 2019 a Univ Lyon, Universit´eLyon 1, LIRIS UMR CNRS 5205, F-69621, Lyon, France [email protected] b Department of Pure and Applied Mathematics, University of Johannesburg, Auckland Park 2006, South Africa [email protected] c Faculty of Mathematics and Physics, University of Ljubljana, Slovenia [email protected] [email protected] d Institute of Mathematics, Physics and Mechanics, Ljubljana, Slovenia e Faculty of Natural Sciences and Mathematics, University of Maribor, Slovenia Abstract Maker-Breaker total domination game in graphs is introduced as a natu- ral counterpart to the Maker-Breaker domination game recently studied by Duch^ene,Gledel, Parreau, and Renault.
- 
												  2- Dominator Coloring for Various Graphs in Graph TheoryInternational Journal of Science and Research (IJSR) ISSN (Online): 2319-7064 Index Copernicus Value (2013): 6.14 | Impact Factor (2015): 6.391 2- Dominator Coloring for Various Graphs in Graph Theory A. Sangeetha Devi1, M. M. Shanmugapriya2 1Research Scholar, Department of Mathematics, Karpagam University, Coimbatore-21, India . 2Assistant Professor, Department of Mathematics, Karpagam University, Coimbatore-21, India Abstract: Given a graph G, the dominator coloring problem seeks a proper coloring of G with the additional property that every vertex in the graphG dominates at least 2-color class. In this paper, as an extension of Dominator coloring such that various graph using 2- dominator coloring has been discussed. Keywords: 2-Dominator Coloring, Barbell Graph, Star Graph, Banana Tree, Wheel Graph 1. Introduction of all the pendent vertices of G by „n‟ different colors. Introduce two new colors „퐶푖 „, „퐶푗 ‟alternatively to the In graph theory, coloring and dominating are two important subdividing vertices of G, C0 will dominates „퐶푖 „, „퐶푗 ‟. Also areas which have been extensively studied. The fundamental all the pendent verticies of G dominates at least two color parameter in the theory of graph coloring is the chromatic class. i.e, 1+n+2 ≤ 푛 + 3. Therefore χ푑,2 {C [ 푆1,푛 ] }≤ 푛 + number χ (G) of a graph G which is defined to be the 3 , n≥ 3. minimum number of colors required to color the vertices of G in such a way that no two adjacent vertices receive the Theorem 2.2 same color. If χ (G) = k, we say that G is k-chromatic. Let 푆 be a star graph, then χ (푆 ) =2, n 1,푛 푑,2 1,푛 .2 A dominating set S is a subset of the vertices in a graph such that every vertex in the graph either belongs to S or has a Proof: neighbor in S.
- 
												  An Experimental Study of Dynamic Dominators∗An Experimental Study of Dynamic Dominators∗ Loukas Georgiadis1 Giuseppe F. Italiano2 Luigi Laura3 Federico Santaroni2 April 12, 2016 Abstract Motivated by recent applications of dominator computations, we consider the problem of dynamically maintaining the dominators of flow graphs through a sequence of insertions and deletions of edges. Our main theoretical contribution is a simple incremental algorithm that maintains the dominator tree of a flow graph with n vertices through a sequence of k edge in- sertions in O(m minfn; kg + kn) time, where m is the total number of edges after all insertions. Moreover, we can test in constant time if a vertex u dominates a vertex v, for any pair of query vertices u and v. Next, we present a new decremental algorithm to update a dominator tree through a sequence of edge deletions. Although our new decremental algorithm is not asymp- totically faster than repeated applications of a static algorithm, i.e., it runs in O(mk) time for k edge deletions, it performs well in practice. By combining our new incremental and decremen- tal algorithms we obtain a fully dynamic algorithm that maintains the dominator tree through intermixed sequence of insertions and deletions of edges. Finally, we present efficient imple- mentations of our new algorithms as well as of existing algorithms, and conduct an extensive experimental study on real-world graphs taken from a variety of application areas. 1 Introduction A flow graph G = (V; E; s) is a directed graph with a distinguished start vertex s 2 V . A vertex v is reachable in G if there is a path from s to v; v is unreachable if no such path exists.
- 
												  Improving the Compilation Process Using Program AnnotationsPOLITECNICO DI MILANO Corso di Laurea Magistrale in Ingegneria Informatica Dipartimento di Elettronica, Informazione e Bioingegneria Improving the Compilation process using Program Annotations Relatore: Prof. Giovanni Agosta Correlatore: Prof. Lenore Zuck Tesi di Laurea di: Niko Zarzani, matricola 783452 Anno Accademico 2012-2013 Alla mia famiglia Alla mia ragazza Ai miei amici Ringraziamenti Ringrazio in primis i miei relatori, Prof. Giovanni Agosta e Prof. Lenore Zuck, per la loro disponibilità, i loro preziosi consigli e il loro sostegno. Grazie per avermi seguito sia nel corso della tesi che della mia carriera universitaria. Ringrazio poi tutti coloro con cui ho avuto modo di confrontarmi durante la mia ricerca, Dr. Venkat N. Venkatakrishnan, Dr. Rigel Gjomemo, Dr. Phu H. H. Phung e Giacomo Tagliabure, che mi sono stati accanto sin dall’inizio del mio percorso di tesi. Voglio ringraziare con tutto il cuore la mia famiglia per il prezioso sup- porto in questi anni di studi e Camilla per tutto l’amore che mi ha dato anche nei momenti più critici di questo percorso. Non avrei potuto su- perare questa avventura senza voi al mio fianco. Ringrazio le mie amiche e i miei amici più cari Ilaria, Carolina, Elisa, Riccardo e Marco per la nostra speciale amicizia a distanza e tutte le risate fatte assieme. Infine tutti i miei conquilini, dai più ai meno nerd, per i bei momenti pas- sati assieme. Ricorderò per sempre questi ultimi anni come un’esperienza stupenda che avete reso memorabile. Mi mancherete tutti. Contents 1 Introduction 1 2 Background 3 2.1 Annotated Code . .3 2.2 Sources of annotated code .
- 
												  Incremental 2-Edge-Connectivity in Directed GraphsIncremental 2-Edge-Connectivity In Directed Graphs Loukas Georgiadis Giuseppe F. Italiano Nikos Parotsidis University of Ioannina University of Rome University of Rome Greece Tor Vergata Tor Vergata Italy Italy ICALP 2016, Rome Outline Definitions • 2-edge-connectivity in undirected graphs • 2-edge-connectivity in directed graphs • Problem definition • Known algorithm and our result High-level idea Basic ingredients • Dominators • Auxiliary components Tools Conclusion ICALP 2016, Rome Outline Definitions • 2-edge-connectivity in undirected graphs • 2-edge-connectivity in directed graphs • Problem definition • Known algorithm and our result High-level idea Basic ingredients • Dominators • Auxiliary components Tools Conclusion ICALP 2016, Rome Undirected: Connected components Let 퐺 = (푉, 퐸) be a undirected graph. • 퐺 is connected if there is a path between any two vertices. • The connected components of 퐺 are its maximal connected subgraphs. ICALP 2016, Rome Undirected: Connected components Let 퐺 = (푉, 퐸) be a connected undirected graph. • An edge is a bridge, if its removal increases the number of connected components. ICALP 2016, Rome Undirected: Connected components Let 퐺 = (푉, 퐸) be a connected undirected graph. • An edge is a bridge, if its removal increases the number of connected components. ICALP 2016, Rome Undirected: Connected components By Menger’s theorem, two vertices are 2-edge- connected iff the removal of any bridge leaves them in the same connected component. ICALP 2016, Rome Undirected: Connected components By Menger’s theorem, two vertices are 2-edge- connected iff the removal of any bridge leaves them in the same connected component. ICALP 2016, Rome Undirected: Connected components By Menger’s theorem, two vertices are 2-edge- connected iff the removal of any bridge leaves them in the same connected component.