Graph Theory Basics and Applications
Graph Theory Basics and Applications
Eric Shen
        The contents of this handout are based on various lectures on graph theory I
      have heard over the years, including some from MOP and some from Canada/USA
      Mathcamp.
Contents
1. Basic terminology                                                                                                                                                     3
   1.1. Introduction to graphs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .                                                                           3
   1.2. Dictionary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .                                                                         3
3. Colorings of graphs                                                                                                                                                   7
   3.1. Introduction to coloring         .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   7
   3.2. Planar graphs . . . . .          .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   7
   3.3. Four-color theorem . .           .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   8
   3.4. Example problems . . .           .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   8
4. Combinatorial constructions                                                                                                                                           10
   4.1. Basic graph constructions . .                .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   10
   4.2. Perfect matchings . . . . . .                .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   11
   4.3. Corollaries of Hall’s theorem                .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   11
   4.4. A hard walkthrough . . . . .                 .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   12
                                                                     1
Graph theory                                                                             Eric Shen (Friday, August 28, 2020)
7. Practice problems 21
8. Solutions to walkthroughs                                                                                                                             23
   8.1. Solution 2.6 . . . . . . . . . . . .     .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   23
   8.2. Solution 2.7 . . . . . . . . . . . .     .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   23
   8.3. Solution 2.8 (HMIC 2020/2) . . .         .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   23
   8.4. Solution 3.1 . . . . . . . . . . . .     .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   24
   8.5. Solution 3.10 (Six-color theorem)        .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   24
   8.6. Solution 3.11 (HMMT 2018 T9) .           .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   24
   8.7. Solution 3.12 (USA TST 2015/5)           .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   25
   8.8. Solution 4.1 . . . . . . . . . . . .     .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   25
   8.9. Solution 4.2 . . . . . . . . . . . .     .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   25
   8.10. Solution 4.3 . . . . . . . . . . . .    .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   26
   8.11. Solution 4.4 . . . . . . . . . . . .    .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   26
   8.12. Solution 4.8 (RMM 2020/3) . . .         .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   26
   8.13. Solution 5.10 (TSTST 2014/5) . .        .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   27
   8.14. Solution 5.11 (Folklore) . . . . . .    .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   27
   8.15. Solution 5.12 (ISL 2004 C8) . . .       .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   28
                                                     2
Graph theory                                                      Eric Shen (Friday, August 28, 2020)
§1     Basic terminology
§1.1    Introduction to graphs
Remark. Beyond this section, all graphs mentioned are simple unless otherwise specified.
When we draw graphs, we think of the edges as connecting pairs of vertices, and represent edges
by connecting their endpoints with curves.
  Below is the famous Petersen graph.
Question 1.3. Which of the following graphs are isomorphic to the Petersen graph?
§1.2    Dictionary
     • Two vertices are adjacent they are connected by an edge. We also say they are neigh-
       bors.
                                                 3
Graph theory                                                                     Eric Shen (Friday, August 28, 2020)
§2.1 Trees
To prove Theorem 2.1, we will show that (i) and (ii) are equivalent definitions.
 1
     It turns out that the connected components of a forest are all trees, so it is fun to say, “A forest is a collection
      of trees.”
                                                             4
Graph theory                                                      Eric Shen (Friday, August 28, 2020)
(ii) implies (i) Indeed, a graph obeying (ii) is a graph and connected (by construction). We
will show it is acyclic.
   Assume not, so we have a cycle. Let v be the vertex in the cycle that was added last. Then
along with v we must have added two edges, contradiction.
  Lemma 2.2
  Every acyclic connected graph has a leaf.
Proof of lemma. Evidently no vertex has degree 0, since the graph is connected. Assume for
contradiction all degrees are at least two. Start with a vertex, traverse an incident edge, and
whenever we arrive at a vertex, traverse another edge incident to that vertex. By infinite
Pigeonhole, we eventually end up at a vertex twice, so we have found a cycle.
  Now we can grab a leaf v0 and delete it, along with its incident edge. Then we have fewer
cycles, so still acyclic, and the graph is still connected since no path between any two remaining
vertices involves v0 .
  Thus the resulting graph is also acyclic connected, so we can finish by induction.
Exercise 2.4. For n ≥ 3, prove that every n-vertex graph with exactly n − 3 edges contains at
least three connected components.
Alternate proof of Lemma 2.2. By Theorem 2.4, the sum of the degrees is 2n − 2. Since all
vertices have nonzero degree, there exists a vertex of degree less than two (say, by Pigeonhole).
                                                 5
Graph theory                                                     Eric Shen (Friday, August 28, 2020)
Walkthrough. Say a vertex is good if it has an odd number of toll roads, and bad otherwise.
(b) Prove that the number of bad vertices, so we can pair them up.
 (c) For every pair of bad toll roads u, v, come up with a scheme to “toggle” a few toll roads
     such that u, v are no longer bad, and no additional bad vertices are created.
  Example 2.7
  Suppose that an arrow is drawn on each edge of a cube, giving each edge a direction, in
  such a way that every vertex of the cube has at least one arrow coming out of it and at
  least one arrow going into it. Prove that under these conditions, it is always possible to
  find a face of the cube such that the directions of the boundary edges of that face go in a
  cycle.
Walkthrough. I managed to casework bash this once. I do not recommend. Assume for
contradiction every vertex has at least one arrow coming in and at least one going out, but no
face goes in a cycle
 (a) Say an angle of a face is good if it can be traversed along the drawing arrows, and bad
     otherwise. (So, every face of the cube has four angles, and every vertex of the cube has
     three angles.)
(b) Show that each face has at most two good angles.
(c) Show that each vertex of the cube has at least two good angles.
(d) Count the number of good angles in two ways. Derive a contradiction therefrom.
     • For each bishop, there exists a knight on the same diagonal as that bishop (there may
       be another piece between the bishop and the knight).
                                                             √
     • For each knight, there exists a bishop that is exactly 5 units away from it.
     • If any piece is removed from the board, then at least one of the above conditions is
       no longer satisfied.
If n is the total number of pieces on the board, find all possible values of n.
 (b) Consider a directed graph where each node is either a bishop of a knight, and there is an
     edge from a bishop to a knight if the bishop attacks the knight, and vice versa. (No edges
     point from a bishop to a bishop, or a knight to a knight.)
                                                6
Graph theory                                                     Eric Shen (Friday, August 28, 2020)
 (c) Verify that all outdegrees are at least 1. Delete some edges from the graph—so it no
     longer obeys the rule in (b)—such that all outdegrees are exactly 1.
 (f ) Prove that each cycle has length a multiple of four, by checkerboard coloring the chess-
      board.
§3     Colorings of graphs
§3.1   Introduction to coloring
  Example 3.1
  Determine the minimum integer L such that every superposition of two trees on the same
  vertex set can be vertex-colored using at most L colors.
Walkthrough. (a) Prove that L > 2 by finding a superposition of two trees that can’t be
    colored using two colors.
 (b) Prove that L > 2 by finding a superposition of two trees that can’t be colored using three
     colors. (Hint: four vertices.)
(c) Show that any tree can be colored with two vertices.
 (d) Show that any superposition of two trees can be colored using four vertices. Thus the
     answer is L = 4.
  Definition 3.2
  Planar graphs can be drawn in R2 with no crossing edges.
Exercise 3.6. Try the proof on your own; it’s a simple induction. Recall that when inducting
in graph theory, we usually look for something to delete.
Proof. We are going to induct on F , with base case    F = 1 for trees.
  Now take any two faces that share an edge e, and     delete e. Then the resulting graph has the
same number of vertices V 0 = V , one fewer face F 0   = F − 1, and one fewer edge E 0 = E − 1.
Given V 0 − E 0 + F 0 = 2, we have V − E + F = 2 as    well.
                                                7
Graph theory                                                     Eric Shen (Friday, August 28, 2020)
 Theorem 3.7
 In planar graphs with V ≥ 3, we have E ≤ 3V − 6.
Exercise 3.8. Use Theorem 3.7 to show K5 and K3,3 are not planar.
  Remark. It turns out, K5 are sort of the “building blocks” of non-planar graphs. Kuratowski’s
  theorem states that a graph is non-planar if and only if it contains a subgraph that is homeo-
  morphic to either K5 or K3,3 .
     Let me explain what this means: a subdivision of an edge u ∼ v involves deleting the edge
  u ∼ v, adding a vertex w, and drawing the edges u ∼ w, w ∼ v. A subdivision of a graph G is a
  graph resulting from the subdivision of the edges in G.
     Then G and H are homeomorphic if there some subdivison of G and some subdivison of H are
  isomorphic.
The proof is hard, and the only known proof requires checking thousands of cases by hand
(clarification: by computer).
   We will prove a weaker version:
 (a) We will pick some vertex v, delete v, color the resulting subgraph in six colors as promised,
     then add v back. Which vertex v should we delete?
(b) Show that every planar graph has a vertex of degree at most 5. (Hint: use a theorem in
    §3.2.)
(c) Show that v can be colored appropriately and finish the proof.
                                                8
Graph theory                                                      Eric Shen (Friday, August 28, 2020)
(b) Try to interpret the quantity 21 (e − v + 1). It may help to write it as 12 [e − (v − 1)].
 (c) Motivated by (b), we will actually induct on e. To begin the induction, settle the base
     case e = v − 1.
 (d) Determine a familiar graph such that we can delete half of its edges so that each vertex
     still has exactly half its original degree.
 (e) Keep on deleting (d) via induction so that we may assume (d) is no longer a subgraph of
     G.
(f ) Show that, now that there are no more instances of (d), that all odd cycles are disjoint.
 (g) The bound is now very weak: conclude the proof by just removing something from each
     cycle.
Walkthrough. We first need to use some rough estimates to extract the answer.
 (a) Let f (n) be the answer. Verify that f (2) = 1, f (3) = 2, f (4) = 3.
 (b) Show that f (a + b) ≤ max(f (a), f (b)) + 1. Assuming this bound is sharp, determine the
     order of magnitude of f (n).
(c) To strengthen our confidence in (b), also show that f (ab) ≤ f (a) + f (b).
 (d) Now attack from the other direction: prove by induction on k that f (2k ) ≥ f (2k−1 ) + 1,
     and some node has f (2k ) incoming colors.
Now it seems clear the answer is dlog2 ne.
 (e) This is the magic step: interpret the condition that −     → −
                                                               uv,   → are different colors in the
                                                                    vw
     following way: for each i, every node is either i-incoming (meaning accepts incoming
     edges of color i) or i-outgoing (meaning emits outgoing edges of color i), but not both.
     It’s possible for that neither holds; in that case, it really doesn’t matter — just say it is
     i-incoming for convenience.
                                                 9
Graph theory                                                     Eric Shen (Friday, August 28, 2020)
 (f ) Let each node have a signature, a binary string of k bits (where k is the number of colors)
      such that the ith bit equals 0 if the vertex is i-incoming and 1 if the vertex is i-outgoing.
 (h) Conversely, prove that if n ≤ 2k , then it is possible to assign signatures to each vertex,
     i.e. such a graph exists.
§4     Combinatorial constructions
§4.1   Basic graph constructions
  Example 4.1
  A tournament is a directed graph with an edge between any two vertices. For every n,
  show that there is a tournament on n vertices such that at each vertex, the outdegree and
  indegree differ by at most 1.
  Example 4.2
  For every n, show that there is a “half-graph,” where every vertex degree is within ±1 of
  n−1                                               1 n
   2 , and the total number of edges is as close to 2 2 as possible.
 (a) For n ≡ 1 (mod 4), come up with a solution in a similar manner to your constructions in
     Example 4.1
 (c) There is an excess of edges. Make a few adjustments to drop the total edge count down
     to an acceptable amount.
 (e) Building off of (d), add an “almost perfect matching” to obtain an acceptable graph for
     n prime.
 (f ) Now generalize to all n replacing cycles with general two-factors: graphs where every
      vertex has degree two. All cycles are two-factors, but not the other way around; for
      instance, the following:
                                                10
Graph theory                                                         Eric Shen (Friday, August 28, 2020)
  Example 4.3
  For every even n, there is a partition of the edges of Kn into n − 1 perfect matchings. For
  every odd n, there is a partition of the edges of Kn into n almost-perfect matchings.
Walkthrough. Mainly experimentation with small n. See the full solution at the end.
  Example 4.4
                                                                                              n
                                                                                                    
  Show that it is possible to partition the set of all subsets of {1, 2, . . . , n} into    bn/2c       lists
  such taht each list (S1 , S2 , S3 , . . .) has the property that S1 ⊂ S2 ⊂ S3 ⊂ · · · .
 (a) Draw a Hasse diagram on the subsets of {1, 2, . . . , n}, where we draw an arrow from A
     to B whenever A ⊂ B.
 (b) Using the Hasse diagram, reduce the problem to finding a perfect matching from subsets
     of size m + 1 to subsets of size m, for m ≥ n/2. (In this context, it means every vertex of
     the important group gets a different vertex of the other group.)
(c) Verify the condition of Hall’s theorem and solve the problem for n even.
  Corollary 4.6
  Consider a bipartite graph G with input set A, output set B, and |A| ≤ |B|. Suppose that
  the degrees of all vertices in A are the same, and the degrees of all the vertices in B are the
  same. Then there is a perfect matching from A → B.
                                                   11
Graph theory                                                          Eric Shen (Friday, August 28, 2020)
  Corollary 4.7
  Suppose |A| = |B| in the above configuration. If we delete a perfect matching, the resulting
  graph still has the aforementioned property. Rinse and repeat, and we have a perfect
  matching partition.
Walkthrough. Before we tackle the RMM problem, let’s borrow a powerful tool from computer
science:
(a) The proof of the existence of spanning trees is another induction. Try it yourself.
 (b) Verify that we can easily create a spanning tree with the following algorithm: start with
     a single point in our spanning tree, and keep on selecting vertices connected by a single
     edge to our spanning tree, and adding that vertex along with its edge.
 (c) For extra practice, show that in a weighted graph, by greedily adding the vertex whose
     edge has minimal distance to the spanning tree, we construct the spanning tree with least
     edge sum. This is Prim’s algorithm for minimum spanning trees.
Now we can work on the RMM problem. We are given a graph of n vertices, and n odd cycles
of different colors. The task is to show there is an odd cycle, all of whose edges have distinct
colors.
   We will try to construct a spanning tree on the n vertices of the graph, where each edge is a
distinct color.
 (d) Begin as you would on (b). Start with an edge (i.e. tree with two vertices) and iteratively
     add vertices to our tree.
 (e) Say that at some step in the process, we have a tree on the vertices v1 , . . . , vk with k < n,
     and that the k − 1 edges cover k − 1 distinct colors. Then there are three cases:
        (i) There is another color whose cycle contains some vertex in {v1 , . . . , vk } but also some
            vertex in V \ {v1 , . . . , vk }.
       (ii) There is another color whose cycle is contained entirely in {v1 , . . . , vk }.
       (iii) No other colors have cycles that contain an element of {v1 , . . . , vk }.
                                                   12
Graph theory                                                                     Eric Shen (Friday, August 28, 2020)
 (f ) In the case of (i), find a way to increase the size of our spanning tree.
 (g) In the cases of (ii) or (iii), use the inductive hypothesis to solve the problem.
Now assume (ii), (iii) never happen, so we finish the process and end up with a spanning tree
with n − 1 edges of distinct colors.
  Part II: Using the spanning tree. We have a spanning tree n − 1 edges of distinct colors.
There is a remaining color, so let x1 ∼ x2 ∼ · · · ∼ xm ∼ x1 (with m odd) be the cycle of the
remaining color.
 (h) For each i, let `i be the distance from xi to xi+1 (indices modulo m) in the spanning tree.
     Verify that
                                      `1 + `2 + · · · + `m is even.
 (i) Use (h) to conclude that for some i, the union of the path from xi to xi+1 on the spanning
     tree with the edge xi ∼ xi+1 is an odd cycle all of whose edges are distinct colors. Conclude.
Proof. Let G have m edges. Since G is triangle-free, for any adjacent vertices x ∼ y, we have
deg x + deg y ≤ n, since N (x), N (y) must be disjoint.
  Summing over all edges,           X
                                       (deg x + deg y) ≤ mn.
                                     x∼y
By Jensen’s inequality,
                                                                                       !2                2
                X                         X                   Jensen       X deg x                   2m
                                                          2
         mn ≥         (deg x + deg y) =         (deg x)        ≥       n                    =n                 ,
                x∼y
                                                                               n                      n
                                          x∈V                              x∈V
Alternate proof. An independent set is a set of vertices whose induced subgraph has no edges.
Let ∆(G) be the maximum degree among the vertices of G.
  Let A is the independent set of maximal size. Since G is triangle-free, N (x) is independent
for all x, so ∆(G) ≤ |A|. Let B = V \ A.
  Since A is independent, every edge must touch a vertex in B, so
                                                             |A| + |B| 2 n2
                      X                                              
                 m≤       deg x ≤ |B| · ∆(G) ≤ |B| · |A| ≤              =    .
                                                                 2         4
                        x∈B
                                                     13
Graph theory                                                       Eric Shen (Friday, August 28, 2020)
§5.2 Formalization
  Definition 5.3
  Let H be a graph with n ≥ |H|. Then G is extremal (for n, H) if H * G and G has the
  maximum number of edges possible for any n-vertex, H-free graph.
  Definition 5.4
  A graph not containing H is edge maximal with respect to H if the addition of any edge
  would create a copy of H.
The difference is that edge maximality is sort of a “local maximum.” Some graphs may be edge
maximal, but not extremal, but all extremal graphs are edge maximal.
We’ve seen that ex(n, K3 ) = bn2 /4c by Mantel’s theorem.           Our goal will be to compute
ex(n, Kr+1 ).
Fact 5.7. Of complete k-partite graphs on n vertices, Tk (n) has the most edges.
Proof. AM-GM.
  Theorem 5.8
  For any r, n ∈ N,
                                                 n2
                                                           
                                                          1
                                      tr (n) ≤         1−     ,
                                                 2        r
  with equality iff r | n.
                                                  14
Graph theory                                                     Eric Shen (Friday, August 28, 2020)
                                          n2    n2
                                                           
                                                          1
                             m ≤ tr (n) ≤     ≤      1− 2 .
                                           2     2       r
Proof of bound. We will induct on n. For the base case n ≤ r, there is nothing to show.
  Consider n > r. It suffices to only consider G that are edge-maximal wrt. Kr+1 ; therefore, G
has Kr as a subgraph. Let’s name our Kr subgraph K, so
                     m ≤ (# in G − K) + (# between G, K) + (# in K)
                                                        
                                                        r
                       = tr (n − r) + (n − r)(r − 1) +    .
                                                        2
I claim this is just equal to tr−1 (n). We will find all three terms in a Turán graph.
   For the 2r term, take one vertex from each partition in the r-partite graph, thereby forming a
Kr . Color these vertices red, and the rest of the vertices blue. Then tr (n−r) counts the number
of blue-blue edges and (n − r)(r − 1) counts the number of blue-red edges. End proof.
Proof of equality case. We’ve shown Turán graphs achieve equality, so let’s prove equality im-
plies Turán graph.
   We can run add on to our above induction. Let the vertices of K be x1 , . . . , xr . Define
Vi = {v ∈ V | vxi ∈ E}. For equality to hold, all Vi are pairwise disjoint, and each is
independent. Thus G is an (r − 1)-partite graph.
   End proof since Turán graphs are the unique maimum.
Walkthrough. (a) Identify an r such that each edge of Kr cannot be colored either red or
    blue such that there is no monochromatic cycle of length 3 nor 5.
 (b) Show that such a graph as described in the problem is Kr -free, and apply Turán’s theorem
     for an upper bound. If done property, the bound should be sharp.
(c) Find an equality case (i.e. where the Turán bounds above are sharp) with 4-vertex graphs.
                                                15
Graph theory                                                               Eric Shen (Friday, August 28, 2020)
 (b) Assume the hypothesis for n − 1. Show that for graphs G with 2n vertices and n2 + 1
     edges, there is at least one triangle uvw.
g(G)3 ≤ c · f (G)4
Walkthrough.
(a) The equality case is quite standard. Try to guess the answer.
Let the vertices of G be v1 , . . . , vn , and let ei edges contain vi , let fi triangles contain vi , and
let gi tetrahedrons contain vi . Also let G contain E edges, F triangles, and G tetrahedrons.
                        P                 P            P
 (b) Verify that 2E =      ei , 3F =        fi , 4G = gi .
      That is, we want to bound fi ≤ something in terms of e. Take advantage of the degrees
      of the variables to pick something to fill the blank.
 (e) Now to extend to G3 ≤ c · F 4 , we would do something similar. First verify that gi2 ≤ c0 fi3
     using (d).
 (g) Hopefully your value of c in (f) matches your answer to (a). If it doesn’t, let equality hold
     at all inequalities to rigorously determine the correct value of c.
(h) Conclude.
                                                         16
Graph theory                                                    Eric Shen (Friday, August 28, 2020)
       • edges may cross, but at most two edges cross at any point,
       • edges don’t go through vertices except at endpoints, and
       • edges sharing a vertex don’t cross.
Hence,
                                           jmk m − 1 jnk n − 1
                             cr(Km,n ) =                              .
                                            2     2     2      2
In both conjectures, we know the upper bound. Lower bounds are harder than upper bounds.
  Theorem 6.5
  If G is planar, then e < 3v.
We’ve already proven this. (In fact, we’ve proven e ≤ 3v − 6 for v ≥ 3.)
                                                 17
Graph theory                                                         Eric Shen (Friday, August 28, 2020)
  Corollary 6.6
  For all G, we have cr(G) > e − 3v.
Proof. Fix a drawing with exactly cr(G) crossings. Form a new graph G0 by arbitrarily deleting
one edge from each crossing.
  Then v(G0 ) = v(G), e(G0 ) ≥ e(G) − cr(G), and G0 is planar, so e(G0 ) < 3v(G0 ). Hence
  Remark. The best constant to replace 64 known is 29. But what really matters is the order of
  magnitude.
Proof of Theorem 5.7 by Lovász, Matoušek, Pach, et al. We will boost Corollary 5.6 to obtain
this stronger result, by deleting vertices. But cleverly choosing vertices to delete is difficult, so
screw that — delete vertices at random.
   We fix some parameter p ∈ [0, 1]. Given G, fix a drawing of G with cr(G) crossings. Let Gp be
a random induced subgraph of G gotten by keeping each vertex independently with probability
p. Then v(Gp ), e(Gp ), cr(Gp ) are random.
                                        E[v(Gp )] = p · v(G)
                                        E[e(Gp )] = p2 e(G)
                                       E[cr(Gp )] ≤ p4 cr(G).
                                            e2          e3        e3
                                 cr(G) ≥         e − 3       v =     .
                                           16v 2       64v 3     64v
                                                  18
Graph theory                                                     Eric Shen (Friday, August 28, 2020)
  What is u(n)?
                                        √    √
Suppose n perfect square. Let S be a n × n unit square grid. For “most” points of S, they
are at unit distance from four other points of S. Here, u(S) ≈ 2n.
  A triangular grid should do better, but we can do even better than that. Let S5 be the same
grid, but dilated down by a factor of 1/5. Why five? Because 52 = 32 + 42 . Then (0, 0) is at
unit distance from 12 points of S5 , namely
                                                        
                                       3 4           4 3
                        (±1, 0),     ± ,±     ,    ± ,±      , (0, ±1).
                                       5 5           5 5
Here, u(S) ≈ 6n.
  Lemma 6.9
  If k is an integer such that k 2 can be written as a sum of two perfect squares in ` ways,
  let Sk be a grid dilated down by 1/k. Almost every point will be at unit distance from `
  others, so
                                                       `n
                                       u(n) ≥ u(Sk ) ≈    .
                                                        2
                            √
Be careful, though! If k > 2n, then diagonal of Sk has length less than one, so we get 0 unit
distances. As k gets larger, the edge effect gets more and more important.
  So now the question is,
Question 6.10. Which k, not too big relative to n, can be written as the sum of two squares
in the most number of ways?
  Exists k such that ` = nc/ log log n . Then c > 0 is an absolute constant, and
This is the best known lower bound, and it’s conjectured this is the best bound.
  Remark. The function we wrote above grows faster than linear functions in n, but slower than
  n1+ε for any ε > 0.
Proof by Székelys. I will prove u(n) ≤ 8n4/3 + n. Let S ⊂ R2 be an arbitrary set of n points.
  Draw a unit circle around every point of S. Then 2u(S) is the number of incidences between
S and these circles. Consider the graph G0 with vertex set S and edges between two vertices
whenever they are consecutive on a unit circle.
  Then
                                                19
Graph theory                                                      Eric Shen (Friday, August 28, 2020)
   • v(G0 ) = n is obvious.
   • e(G0 ) = 2u(S), since if one circle has m points, it contributes m edges to G0 and also m
     incidences between circles and points.
   • cr(G0 ) ≤ 2 n2 < n2 by looking at the graph already drawn for us. Each pair of circles
                   
intersect twice.
A small issue: G0 is not a simple graph, i.e. may be more than one edge between a pair of
vertices. There might also be self-loops. But this is all that can go round; there are at most
four edges connecting any two vertices.
  Let G be gotten from G0 by deleting all this junk: delete all self-loops and keep only one
edge between any two vertices.
Rearranging,
                             e(G0 )               
                         u(S) =     ≤ 2 4n4/3 + n = 8n4/3 + n.
                               2
Remember we needed to assume e ≥ 4v. If not, then 2u(S) = e(G0 ) < 4n and u(S) ≤ 8n.
                                               20
Graph theory                                                             Eric Shen (Friday, August 28, 2020)
§7      Practice problems
Problem 7.1 (BAMO 2004/3, free 2 points). NASA has proposed populating Mars with 2004
settlements. The only way to get from one settlement to another will be by a connecting
tunnel. A bored bureaucrat draws on a map of Mars, randomly placing N tunnels connecting
the settlements in such a way that no two settlements have more than one tunnel connecting
them. What is the smallest value of N that guarantees that, no matter how the tunnels are
drawn, it will be possible to travel between any two settlements?
Problem 7.2. Prove that every connected graph with all degrees even has a Eulerian tour.
Problem 7.3 (MOP 2011 R0.1). Let n be a positive integer. Partition the set {0, . . . , 2n − 1}
into n pairs {a1 , b1 }, {a2 , b2 }, . . ., {an , bn }. For i = 1, . . . , n draw a semicircle above the x-axis
joining (ai , 0) to (bi , 0), and draw a semicircle below the x-axis joining (ai + 1, 0) and (bi + 1, 0).
   Suppose that no two of these semicircles intersect except at their endpoints. Prove that the
union of the semicircles forms a single closed curve from (0, 0) to (2n, 0).
Problem 7.4 (ToT 1986). Twenty football teams take part in a tournament. On the first day
all the teams play one match. On the second day all the teams play a further match. Prove that
after the second day it is possible to select 10 teams, so that no two of them have yet played
each other.
Problem 7.5 (PUMaC 2019/1). A finite graph G is drawn on a blackboard. The following
operation is permitted: pick any cycle C of G, draw a new vertex v, connect it to all vertices
of C, and finally erase all the edges of C. Prove that the operation can only be done a finite
number of times.
Problem 7.6 (China TST 2015/1/3). Fix positive integers k, n. A candy vending machine
has many different colours of candy, where there are 2n candies of each colour. A couple of kids
each buys from the vending machine 2 candies of different colours. Given that for any k + 1
kids there are two kids who have at least one colour of candy in common, find the maximum
number of kids.
Problem 7.7 (ISL 2013 C6). In some country several pairs of cities are connected by direct
two-way flights. It is possible to go from any city to any other by a sequence of flights. The
distance between two cities is defined to be the least possible number of flights required to go
from one of them to the other. It is known that for any city there are at most 100 cities at
distance exactly three from it. Prove that there is no city such that more than 2550 other cities
have distance exactly four from it.
Problem 7.8 (ISL 2005 C4). Let n ≥ 3 be a fixed integer. The edges of the complete graph
Kn are labeled with a number from the set {1, . . . , r} such that
     • in any triangle, two of the edges are labeled with the same number, and this number is
       greater than the label of the third side.
Find the maximal r for which such a labeling is possible, and determine how many such labelings
achieve this maximum.
Problem 7.9. If a graph G has average degree d, then it has a subgraph H ⊂ G whose minimum
degree is at least d/2.
                                                      21
Graph theory                                                   Eric Shen (Friday, August 28, 2020)
Problem 7.10 (Japan 1997/3). Let G be a graph with 9 vertices. Suppose given any five
points of G, there exist at least 2 edges with both endpoints among the five points. What is
the minimum possible number of edges in G?
Problem 7.11 (St. Petersburg 1996/4). In a group of several people, some are acquainted with
each other and some are not. Every evening, one person invites all of his acquaintances to a
party and introduces them to each other. Suppose that after each person has arranged at least
one party, some two people are still unacquainted. Prove that they will not be introduced at
the next party.
Problem 7.12 (Canada 2020/5). Let G be a graph with 19998 vertices so that any 9999-vertex
subgraph of G has at least 9999 edges. Determine the minimum possible number of edges in G.
Problem 7.13. Let G be a finite, simple graph with n ≥ 3 vertices. If deg v + deg w ≥ n for
every pair of non-adjacent vertices v and w of G, then G has a Hamiltonian path.
Problem 7.14 (IMO 2019/3). A social network has 2019 users, some pairs of whom are friends.
Whenever user A is friends with user B, user B is also friends with user A. Events of the
following kind may happen repeatedly, one at a time:
     Three users A, B, and C such that A is friends with both B and C, but B and C
     are not friends, change their friendship statuses such that B and C are now friends,
     but A is no longer friends with B, and no longer friends with C. All other friendship
     statuses are unchanged.
Initially, 1010 users have 1009 friends each, and 1009 users have 1010 friends each. Prove that
there exists a sequence of such events after which each user is friends with at most one other
user.
                                              22
Graph theory                                                     Eric Shen (Friday, August 28, 2020)
§8      Solutions to walkthroughs
§8.1     Solution 2.6
Say a vertex is good if it has an odd number of toll roads, and bad otherwise. Pick a random
                                        P
subset of the edges to be toll roads. By v deg v = 2|E|, an even number of vertices are good,
so an even number of vertices are bad.
   Pair up the bad vertices. For every pair of bad toll roads u, v, take a path between them,
and toggle every edge on the path. We can check that u, v are now good, and all other vertices
in the graph do not change their state. Thus at the end of this process, all vertices are good.
which is absurd.
  Remark. The version of the problem with a cube is from Po-Shen Loh’s lecture “Graph theory:
  introduction” at MOP 2019, which is based on his 21-228 Discrete Mathematics course at Carnegie
  Mellon University.
N N
                                             B
  Now we show 4 | n is necessary. Consider a directed graph where each node is either a bishop
or a knight, and there is an edge from a bishop to a knight if the bishop attacks the knight, and
vice versa. (No edges point from a bishop to a bishop, or a knight to a knight.)
                                               23
Graph theory                                                     Eric Shen (Friday, August 28, 2020)
  We are given each node has outdegree at least 1. For each node v, arbitrarily delete outgoing
edges until the outdegree of v is exactly 1. Then each node has indegree 1, as otherwise some
node has indegree 0 and may be deleted. Hence the graph consists of disjoint cycles.
  It will suffice to show each cycle has length a multiple of 4. Checkerboard color the chessboard:
then for any edge from a bishop to a knight, the two endpoints are the same color, but for any
edge from a knight to a bishop, the two endpoints are different colors. Hence the number of
edges from a knight to a bishop is even, but this is equal to the number of edges from a bishop
to a knight. It follows that the number of edges is a multiple of 4, as desired.
  Lemma
  Every planar graph has a vertex of degree at most 5.
so Pigeonhole applies.
  We backwards induct on V . Find a vertex of degree at most 5, delete it, color the remaining
subgraph, then color v using a color that is not present in the neighborhood of v. (Since
deg v ≤ 5, the neighborhood of v cannot contain all six colors.)
   • If there is an even-length cycle, then remove the cycle, apply the inductive hypothesis on
     the resulting graph, and add back every other edge of the even-length cycle.
   • If there are no even-length cycles, then all odd-length cycles are disjoint, so the number
     of cycles is e − v + 1. Simply remove an edge from each cycle.
That is all.
                                                24
Graph theory                                                     Eric Shen (Friday, August 28, 2020)
   • no two vertices may have the same signature, since otherwise it is impossible to draw an
     edge between them;
• if two vertices have different signatures, then it is possible to draw an edge between.
  Proof for n ≡ 1 (mod 4): Draw an edge between u and v whenever the distance between u
and v is at most n−1                             n−1
                  4 . Then each vertex has degree 2 and the total edge count is
                                                       
                                             n−1     1 n
                               # edges = n ·      =      .
                                               4     2 2
  Proof for n even: First construct the complete bipartite graph Kn/2,n/2 . Each vertex has
degree n2 , so may remove up to one edge from each vertex.
  Remove a total of bn/4c, so that the degree is either n2 of n−2
                                                               2 for each vertex and the total
edge count is
                                       n2 j n k 1 n
                                                       n o
                                                               n
                            # edges =     −      =         +      .
                                       4     4      2 2        4
  Proof for n ≡ 3 (mod 4): For each k ≤ n−3  4 , we can draw a two-factor on the graph of n
vertices where each vertex has degree 2 and every edge connects vertices of distance k. (This
may be a cycle, or a composition of cycles.)
  Then, add an almost perfect matching, so each vertex has degree either n−3      n−1
                                                                           2 or 2 and the
edge count is                                             
                                        n−3 n−1         1 n      1
                         # edges = n ·       +       =        − .
                                          4      2      2 2      2
                                                25
Graph theory                                                       Eric Shen (Friday, August 28, 2020)
  Proof for n even: For each odd i < n/2, we can construct a perfect matching where each
edge has length i, e.g. the following:
  Claim. There is a perfect matching from the set of subsets of size m + 1 to subsets of size
  m, for m ≥ bn/2c.
Proof. Each subset of size m + 1 has m + 1 neighbors, whereas each subset of size m has n − m
neighbors. Verify that n − m ≤ m + 1, then apply Hall matching theorem.
                           n
                              
  Then for each of the bn/2c    subsets of size bn/2c, apply the perfect matchings to turn each
subset into a chain of subsets.
                                                 26
Graph theory                                                        Eric Shen (Friday, August 28, 2020)
  (i) We can find another color whose cycle contains some vertex in {v1 , . . . , vk }, but also
      contains some vertex in V \ {v1 , . . . , vk }. Then there is an edge of this color of the form
      vi ∼ w, where w ∈
                      / {v1 , . . . , vk }. Add this vertex w to the tree.
 (ii) We can find another color whose cycle is contained entirely in {v1 , . . . , vk }. Then there are
      k cycles on the subgraph with vertices {v1 , . . . , vk }, so we win by the inductive hypothesis.
(iii) No other colors have cycles that contain an element of {v1 , . . . , vk }. In the subgraph
      consisting of the remaining n − k vertices, there are n − k cycles, so we win by the
      inductive hypothesis.
If at any point in the process, one of conditions (ii), (iii) holds, then we are already done.
Otherwise, we successfully construct a spanning tree with n − 1 edges of distinct colors.
   Let x1 ∼ x2 ∼ · · · ∼ xm ∼ x1 , with m odd, be the cycle formed by the remaining color, and
consider the paths from x1 to x2 , from x2 to x3 , . . . , from xm to x1 in the spanning tree. The
sum of their lengths must be even, so one of them, say the path from xi to xi+1 (indices modulo
m), has even length.
   Then union this path with the edge xi ∼ xi+1 to construct a cycle of odd size all of whose
edges are distinct colors. End proof.
                                             1 n2
                                              
                                   E ≤ 1−            = 1350,
                                             4 2
as desired.
Proof. If deg u + deg v ≤ 2n, remove u and v. The resulting graph G0 has 2n − 2 vertices and at
least (n − 1)2 + 1 edges. By minimality G0 contains at least n − 1 triangles, so G has n triangles,
contradiction.
But there are 2n − 3 remaining vertices, so by Pigeonhole, there are at least n − 1 additional
triangles containing an edge in {uv, vw, wu} but is not uvw itself.
                                                 27
Graph theory                                                                    Eric Shen (Friday, August 28, 2020)
Claim. F 2 ≤ 29 E 3 .
                                          ei
                                               
Proof. Note that fi ≤ E and fi ≤          2        . Then
                                                    s   r
                             n            n                   n
                             X            X            ei   EX      √
                      3F =         fi ≤              E    <     ei = 2E 3/2 ,
                                                       2    2
                             i=1          i=1                             i=1
  Note the trivial bound gi ≤ F . Consider the subgraph of G comprised of the neighbors of vi
(but not vi ). It contains fi edges and gi triangles, so gi2 ≤ 29 fi3 . Hence
                           n            n      r                  r      n        r
                           X            X              2          3   2F X        3 2
                                                                                      F 4/3 ,
                                               3
                    4G =         gi ≤               F · fi3 =              fi = 3
                                                       9               9            9
                           i=1          i=1                              i=1
                                                    Att+1      t!
                                                      t+1 ≤ (t + 1)t .
                                                    At
                                           n2
                                                           
                                                       1
                               ex(n, H) ≥      1−             .
                                           2       χ(H) − 1
                                                                                    n2
                                                                               
                                                               1
                             ex(n, H) = 1 −                          + o(1)            .
                                                            χ(H) − 1                2
                                                             28
Graph theory                                                                      Eric Shen (Friday, August 28, 2020)
  Theorem A.2
  For every s ≤ t we have
                                s−t−2
                           n(2− st−1 )                 e
                                       ≤ ex(n, Ks,t ) ≤ (t − 1)1/s n2−1/s .
                               16                      2
Upper bound Let G be edge-maximal and have n vertices, m edges; so deg v ≥ s − 1 for all
v ∈V.
  The idea is to count K1,s . There’s going to be so many of these that we can take the obvious
bound for Ks,t . So how many K1,s ’s can we count? Obviously:
                                                          X deg v
                                              #K1,s =             .
                                                              s
                                                          v∈V
We will use Jensen’s inequality along with this lemma to bound #K1,s :
  Lemma A.3
  For integers 1 ≤ k ≤ n,                                  
                                          n k          n   en k
                                                   ≤       ≤      .
                                          k              k    k
By Jensen’s inequality,
                                    X deg v                            2m 2
                                                                         
                                                             2m/n
                          #K1,s =                        ≥n         ≥n        .
                                               s               s         ns
                                    v∈V
  Now I claim #K1,s ≤ (t − 1) ns . The ns represents the number of sets of s vertices, and
                                            
each set of s has at most t − 1 common neighbors. (Else, a Ks,t already exists.) We have
                                             
                                               n            en s
                             #K1,s ≤ (t − 1)     ≤ (t − 1)         .
                                               s              s
                                                          29
Graph theory                                                        Eric Shen (Friday, August 28, 2020)
Lower bound We’ll use the probabilistic method. Let G(n, p) be a random graph on n vertices
where every edge is chosen with probability p. How many edges would you expect?
                                                    pn2
                                              
                                               n
                                   E[m] = p       >     .
                                               2     4
  Now I would also like to count the expected number of Ks,t . We can also do this easily:
                                              
                                         n n − s st
                                                   p ≤ ns+t pst .
                                  
                           E #Ks,t =
                                         s     t
                     s+t−2
By setting p = 12 n−( st−1 ) , one can verify E #Ks,t ≤ 21 E[m] in the form ns+t pst ≤ 18 pn2 .
                                                    
  Hence                                                                     s−t−2
                                                E[m]       pn2     n(2− st−1 )
               E m − #Ks,t = E[m] − E #Ks,t ≥                ≥      =              ,
                                                       2         8         16
                                           1 thing
so there exists a graph G with m − #Ks,t ≥ 16 n     .
  Remove an edge from each Ks,t , leaving a Ks,t -free graph G0 with at least nthing edges re-
maining.
Remark. This was supposedly proven in 2015, but it has not yet been written up. Lame asf.
                                                       n(t − 1)
                                         ex(n, P ) ≤            .
                                                           2
First, a lemma:
  Lemma A.6
  Every graph has a cycle/path of at least δ(G) + 1 vertices, where δ is the minimum degree.
Proof Lemma 8.3. Consider the longest path x1 , . . . , xm . Thus, all neighbors of xm must lie in
the path, so the path contains at least δ(G) + 1 vertices.
  Lemma A.7
  If G is connected, it has a path of length min{n, 2δ(G) + 1}.
                                                  30
Graph theory                                                           Eric Shen (Friday, August 28, 2020)
Proof of claim. There are at least δ(G) neighbors of x1 among {x2 , . . . , xm }. Analogously
among {x1 , . . . , xm−1 } are at least δ(G) neighbors of xm .
  Details omitted, but this should follow from Pigeonhole.                                 
  From this, we have cycle x1 x2 · · · xi xm xm−1 · · · xi+1 x1 of length M . Since it’s the case that
M < n, there’s a vertex y not on the cycle. There should be an index j such that y, xj are
connected via a path that does not intersect any other (xi ). Hence we have a longer path
starting from y and wrapping around the cycle.
  Our initial assumption was incorrect, so it must be the case that M ≥ 2δ + 1. Therefore G
has a path of length min{n, 2δ(G) + 1}.
Proof Theorem 8.2 (Erdős-Gallai). We will induct on the number of vertices in G. The base
case n ≤ t is clear, since G must be P -free. Hence
                                               n(n − 1)   n(t − 1)
                                 ex(n, P ) =            ≤          .
                                                  2           2
Now the inductive step: suppose G has n > t vertices and is P -free.
  First if G is disconnected, just sum over components using the inductive hypothesis:
                                   X           X ni (t − 1)       n(t − 1)
                             m=        mi =                   =            .
                                                       2              2
Suppose G is connected, i.e. has a path of length min{n, 2δ(G) + 1} by the lemma.
   Now if δ(G) ≥ 21 t, then G has a path of length 2δ + 1, contradiction. Hence we may assume
δ(G) < 12 t, so some vertex w has a small degree, i.e. deg w ≤ 21 (t − 1). We will remove w from
our graph.
   Let G0 be G with w removed. Then G0 has at most 12 (n − 1)(t − 1) edges. Adding back the
1
2 (t − 1) edges incident to w, the number of edges in G is at most
                                (n − 1)(t − 1) t − 1   n(t − 1)
                                              +      =          ,
                                      2          2         2
end proof.
  An equality case is r copies of Kt . Thus this upper bound is optimal for infinitely many
values of n, i.e. the bound is pretty good.
31