Graphs#
A graph is a data structure that consists of a set of vertices (also known as nodes) and a set of edges connecting them. The edges represent the relationships or connections between the vertices, and can be directed (pointing from one vertex to another) or undirected (connecting two vertices in both directions).
Graphs can be used to represent a wide range of real-world systems and networks, such as social networks, transportation networks, and computer networks. They are an important tool in computer science and are used in many applications, such as data mining, machine learning, and optimization.
Graphs can be represented in different ways, such as adjacency lists, adjacency matrices, and edge lists. Adjacency lists are a common representation, where each vertex is associated with a list of its adjacent vertices (i.e., the vertices that it is directly connected to).
Graph algorithms are used to analyze and manipulate graphs. Some common graph algorithms include traversal algorithms (such as depth-first search and breadth-first search), shortest path algorithms (such as Dijkstra’s algorithm and the Bellman-Ford algorithm), and minimum spanning tree algorithms (such as Kruskal’s algorithm and Prim’s algorithm).
Overall, graphs are an important data structure in computer science, and understanding them is essential for solving many problems in fields such as computer networking, social network analysis, and transportation planning.
data:image/s3,"s3://crabby-images/3f5b6/3f5b613107d52251882a5cd64b3eab3f5884df3d" alt="https://miro.medium.com/max/2664/1*HYPtf5Vk135snk07gFzy2w.png"
a set of vertices connect pairwise by edges
Vertices
fundamental units of the graph known as vertex or nodes;
every node/vertex can be labeled or unlabelled
Edges
are drawn or used to connect two nodes of the graph
can connect any two nodes in any possible way
can be labeled or unlabelled
data:image/s3,"s3://crabby-images/95302/95302e32d5897da41f30f4782b762194b4290de0" alt="https://media.geeksforgeeks.org/wp-content/uploads/20200630111809/graph18.jpg"
Fig. 70 gfg: graph vertices and edges#
Examples#
data:image/s3,"s3://crabby-images/10c71/10c7109fde5ac1532c1df8c53e2f8ceb3f06e4a9" alt="https://www.maureeneppstein.com/mve_journal/wp-content/uploads/underground-map1.gif"
Fig. 71 London Underground (Tube) Map
vertex = subway stop;
edge = direct route#
Fig. 72 Facebook Social Network Map:
vertex = person;
edge = social relationship#
data:image/s3,"s3://crabby-images/dcf76/dcf76856136302b9b64b3c191c9aa47398da6a08" alt="https://allthingsgraphed.com/public/images/twitter/twitter-follower-graph-avatars.png"
Fig. 73 Twitter followers
vertex = Twitter account;
edge = Twitter follower#
data:image/s3,"s3://crabby-images/c8c08/c8c08ea2693e20c1c7d7a7e7727de456a83f110b" alt="https://www.researchgate.net/publication/314491781/figure/fig5/AS:470414003576837@1489166846626/Protein-protein-network-analysis-based-on-regulated-genes-in-HEK293-cells-Interactions.png"
Fig. 74 Protein-protein interation network
vertex = protein;
edge = interaction#
Applications#
graph |
vertex |
edge |
---|---|---|
cell phone |
phone |
placed call |
infectious disease |
person |
infection |
financial |
stock, currency |
transactions |
transportation |
intersection |
street |
internet |
router |
fiber cable |
web |
web page |
URL link |
social relationship |
person |
friendship |
Graph Types#
data:image/s3,"s3://crabby-images/d04e8/d04e8322b1bcc612e667ccf2d7e4d8dd559b10d2" alt="https://cdn-images-1.medium.com/max/1600/1*fYG3B8hi4O2kk6aHvFB5mg.png"
data:image/s3,"s3://crabby-images/4474e/4474ed8352a73538a87a9cbdf1080e716c644867" alt="../../_images/19_02.png"
Graph Processing Problems#
problem |
description |
---|---|
s-t path |
Find a path between \(s\) and \(t\) |
shortest s-t path |
Find a path with the fewest edges between \(s\) and \(t\) |
cycle |
Find a cycle |
Euler cycle |
Find a cycle that uses each edge exactly once |
Hamilton cycle |
Find a cycle that uses each vertex exactly once |
connectivity |
Is there a path between ev ery pair of vertices? |
graph isomorphism |
Are two graphs isomorphic? |
planarity |
Draw the graph in the plane with no crossing edges |
Representation#
- Vertex representation#
For 0 through all positive values \(V-1\) Applications: use symbol table to convert between names and integers
data:image/s3,"s3://crabby-images/5c207/5c2077a7d74f7e201a3de3adeced5dfe0ee634a5" alt="../../_images/19_03.png"
- Definition#
a digraph is simple if it has no self-loops or parallel edges
data:image/s3,"s3://crabby-images/84dd8/84dd8ab780ebab6764dbf32473f144f231e10b9b" alt="../../_images/19_04.png"
Maintain a \(V-by-V\) boolean array;
For each edge \(v \rightarrow w\) in the digraph
data:image/s3,"s3://crabby-images/5828c/5828cefeddfeed73e9d8fd3d5a14d98f6a215f2c" alt="../../_images/19_05.png"
Maintain vertex-indexed array of lists
data:image/s3,"s3://crabby-images/96257/962574cfb8a677f67b4aa78fe33d7fb2e893812d" alt="../../_images/19_06.png"
- Use adjacency-lists#
Algorithms based on iterating over vertices adjacent from \(v\)
Real-world graphs tend to be sparce (\(\Theta(V)\) edges), not dense (\(\Theta(V^2)\) edges)
representation |
space |
add edge from |
has edge from |
iterate over vertices |
---|---|---|---|---|
adjacent matrix |
\(V^2\) |
1* |
1 |
\(V\) |
adjacent lists |
\(E+V\) |
1 |
\(outdegree(v)\) |
\(outdegree(v)\) |
* disallows parallel edges