(or as I like to call it, combinatrix)
Shortcut to this page: ntrllog.netlify.app/comb
Notes provided by Professor Steven Sam (UCSD)
Number of subsets: `sum_(k=0)^n ((n),(k)) = 2^n`
Pascal's Identity: `((n),(k)) + ((n),(k-1)) = ((n+1),(k))`
Number of `k`-element multisets: `((n+k-1),(k))`
Number of weak compositions into `k` parts: `((n+k-1),(n))`
Number of compositions into `k` parts: `((n-1),(n-k)) = ((n-1),(k-1))`
Number of compositions into all possible parts: `2^(n-1)`
Number of set partitions into `k` blocks: `S(n,k) = S(n-1,k-1) + k*S(n-1,k)`
Bell numbers: `B(n+1) = sum_(i=0)^n ((n),(i))B(i)` and `B(0)=1`
Binomial Theorem: `(x+y)^n = sum_(i=0)^n ((n),(i)) x^iy^(n-i)`
Multinomial Theorem: `(x_1+x_2+...+x_k)^n = sum_(a_1+a_2+...+a_k=n) ((n),((a_1, a_2, ..., a_k))) x_1^(a_1)x_2^(a_2)...x_k^(a_k)`
`sum_(n ge 0) x^n = 1/(1-x)`
Binomial Theorem (General): `(1+x)^m = sum_(n ge 0)((m),(n))x^n`
`((-d),(n)) = (-1)^n((d+n-1),(n)) = (-1)^n((d+n-1),(d-1))`
`(1+x)^(-d) = sum_(n ge 0) (-1)^n((d+n-1),(n))x^n = sum_(n ge 0) (-1)^n((d+n-1),(d-1))x^n`
Product of ogf: `A(x)B(x) = sum_(n ge 0)(sum_(i=0)^na_ib_(n-i))x^n`
Composition of ogf: `B(A(x)) = sum_(n ge 0) b_nA(x)^n`
Catalan numbers: `C_n = 1/(n+1) ((2n),(n))`
Catalan numbers (recurrence): `C_n = sum_(i = 0)^(n-1)C_iC_(n-1-i)` and `C_0 = 1`
`sum_(n ge 0) x^n/(n!) = e^x`
Product of egf: `A(x)B(x) = sum_(n ge 0)(sum_(i=0)^n((n),(i))a_ib_(n-i))x^n/(n!)`
Lagrange Inversion: If `A(x) = xG(A(x))`, then `[x^n]A(x) = 1/n[x^(n-1)](G(x)^n)`
Inclusion-Exclusion: `|A_1 uu A_2 uu ... uu A_n| = sum_(j=1)^n(-1)^(j-1)sum_(1 le i_1 lt i_2 ... lt i_j le n)|A_(i_1) nn A_(i_2) ... nn A_(i_j)|`
Number of derangements: `sum_(i=0)^n(-1)^i(n!)/(i!)`
Number of necklaces: `sum_(d|n)(omega(d))/d`
`omega(d) = sum_(e|d)mu(d/e)k^e`
Theorem: There are `2^n` subsets of a set of size `n`
Let `P(n)` be the statement that there are `2^n` subsets of a set of size `n`
For a set with `0` elements, the only subset is `O/`, which is consistent with `2^0 = 1` so `P(0)` is true
Suppose `P(n)` is true. Want to show `P(n+1)` is true, i.e., there are `2^(n+1)` subsets of a set of size `n+1`
Let `S` be a set of size `n+1`
Fix any `x in S` and consider `S' = S\\{x}`
Since `S'` has `n` elements, there are `2^n` subsets
Every subset of `S` either contains `x` or it doesn't contain `x`
The subsets that don't contain `x` are in `S'`, which has `2^n` subsets
So there are `2^n` subsets that don't contain `x`
The subsets that do contain `x` can be obtained by adding `x` to each of the `2^n` subsets that don't contain `x`
So there are `2^n` subsets that do contain `x`
The total number of subsets of `S` is the number of subsets containing `x` plus the number of the subsets not containing `x`
So the total number of subsets of `S` is `2^n + 2^n = 2*2^(n) = 2^(n+1)`
So `P(n+1)` is true
`sum_(i=0)^n i = (n*(n+1))/2`
Let `P(n)` be the statement `sum_(i=0)^n i = (n*(n+1))/2`
For `n=0`, `sum_(i=0)^0 i = 0` and `(0*(0+1))/2 = 0` so `P(0)` is true
Suppose `P(n)` is true. Want to show `P(n+1)` is true, i.e., `sum_(i=0)^(n+1) i = ((n+1)(n+2))/2`
`sum_(i=0)^(n+1) i = sum_(i=0)^n i + (n+1)`
`= (n*(n+1))/2 + (n+1)`
`= (n^2 + n)/2 + (2(n+1))/2`
`= (n^2 + n)/2 + (2n + 2)/2`
`= (n^2 + 3n + 2)/2`
`= ((n+1)(n+2))/2`
So `P(n+1)` is true
`4n lt 2^n` for `n ge 5`
Let `P(n)` be the statement `4n lt 2^n` for `n ge 5`
For `n=0`, `4*0 = 0 lt 2^0 = 1` so `P(0)` is true
Suppose `P(n)` is true. Want to show `P(n+1)` is true, i.e., `4n+4 lt 2^(n+1)`
`2^(n+1) = 2*2^n`
`= 2^n + 2^n`
`gt 4n + 4n`
`gt 4n + 4` (since `n ge 5`)
So `P(n+1)` is true
Every polynomial in `x` is a linear combination of `1, x-1, (x-1)^2, (x-1)^3, ...`
Let `P(n)` be the statement that every polynomial of degree `n` in `x` is a linear combination of the powers of `x-1`
For `n=0`, the polynomial of degree `0` is a constant `c`, which is a linear combination of `1` (`c = c*1`) so `P(0)` is true
Suppose `P(0), P(1), P(2), ... P(n)` is true. Want to show `P(n+1)` is true, i.e., every polynomial of degree `n+1` in `x` is a linear combination of the powers of `x-1`
Let `f(x)` be a polynomial of degree `n+1`
Let `alpha` be the leading coefficient of `f`
Consider `g(x) = f(x) - alpha*(x-1)^(n+1)`
`g(x)` is a polynomial of degree `le n` so it is a linear combination of the powers of `x-1`
`f(x) = g(x) + alpha*(x-1)^(n+1)`
`alpha*(x-1)^(n+1)` is also a linear combination of the powers of `x-1`
So `f(x)` is a linear combination of the powers of `x-1`
So `P(n+1)` is true
Every positive integer can be written as `2^rm` where `r ge 0` and `m` is an odd integer
Let `P(n)` be the statement that `n` can be written as `2^rm` where `r ge 0` and `m` is odd
For `n=1`, `1 = 2^0*1 = 1` so `P(1)` is true
Suppose `P(1), ..., P(n)` is true. Want to show `P(n+1)` is true, i.e., `n+1` can be written as `2^rm` where `r ge 0` and `m` is odd
Suppose `n+1` is odd. Then pick `r=0` and pick `m = n+1` so `P(n+1)` is true
Suppose `n+1` is even
Then it can be written as `n+1 = 2k` for some integer `1 le k le n`
Since `k` is a positive integer, it can be written as `2^rm` where `r ge 0` and `m` is odd
`n+1 = 2k`
`= 2*2^rm`
`= 2^(r+1)m`
`m` is odd and `r ge 0 implies r+1 ge 0` so `n+1` can be written as a power of `2` multiplied by an odd number
So `P(n+1)` is true
Every integer `n ge 2` can be written as a product of prime numbers
Let `P(n)` be the statement that `n` can be written as a product of prime numbers
For `n=2`, `2` is a product of `2`, which is a prime number so `P(2)` is true
Suppose `P(2), ..., P(n)` is true. Want to show `P(n+1)` is true, i.e., `n+1` can be written as a product of prime numbers
Suppose `n+1` is prime. Then it is a product of itself so `P(n+1)` is true
Suppose `n+1` is not prime
Then `n+1` can be written as `n+1 = a*b` for integers `a,b` where `2 le a,b le n`
Since `2 le a,b le n`, `a` and `b` can be written as products of prime numbers
So `n+1` is a product of prime numbers
So `P(n+1)` is true
Let `f` be a function so that `f(0)=1`, `f(1)=2`, and `f(n+1)=f(n-1)+2f(n)` for `n ge 1`. Show that `f(n) le 3^n` for `n ge 0`
Let `P(n)` be the statement that `f(n) le 3^n` for `n ge 0`
For `n=0`, `f(0) = 1 le 3^0 = 1`
For `n=1`, `f(1) = 2 le 3^1 = 3`
So `P(0)` and `P(1)` are true
Suppose `P(n)` is true. Want to show that `P(n+1)` is true, i.e., `f(n+1) le 3^(n+1)`
`f(n+1) = f(n-1)+2f(n)`
`le 3^(n-1) + 2*3^n`
`= 3^(n-1) + 3^n + 3^n`
`le 3^n + 3^n + 3^n`
`= 3*3^n`
`= 3^(n+1)`
So `P(n+1)` is true
Given a set `S` of objects, a permutation of `S` is a way to put all elements of `S` in order
Example: For `S = {1,2,3}`, all the permutations are:
`1,2,3`
`1,3,2`
`2,1,3`
`2,3,1`
`3,1,2`
`3,2,1`
Theorem: If `S` has `n gt 0` elements, then there are `n!` permutations of the elements in `S`
Let `P(n)` be the statement that if `S` has `n gt 0` elements, then there are `n!` permutations of the elements of `S`
For a set of size `1`, there's only `1` way to order all the elements. `1 = 1!` so `P(1)` is true
Suppose `P(n)` is true. Want to show `P(n+1)` is true, i.e., if `S` has `n+1` elements, then there are `(n+1)!` permutations of the elements in `S`
Let `S` be a set of size `n+1`
We could pick any random element of `S` and put that in the first spot
There are `n+1` choices for the random element in the first spot
Now, `S` has `n` elements
So there are `n!` ways to order the remaining elements in `S`
So the total number of ways to order the elements is `(n+1)*n! = (n+1)!`
So `P(n+1)` is true
Intuitively, there are `n` choices for the first digit, `n-1` choices for the second digit, `n-2` choices for the third digit, ..., all the way down to `1` choice for the last digit
So there are `n*(n-1)*(n-2)*...*1 = n!` ways to order the elements
Let's suppose we're arranging flowers. We have `2` red flowers and `1` yellow flower. How many ways can we arrange them? Previously, we saw that if we have `n` elements, there are `n!` ways to arrange them. Here, we have `3` elements, so there are `3! = 6` ways to arrange them. All the possible orderings are:
`R RY`
`R RY`
`YR R`
`YR R`
`RYR`
`RYR`
But some of the orderings are repeated. This is because the `2` red flowers are technically different flowers, but the order in which they appear doesn't matter; the result is the same. So we have to divide out the commonalities. In this case, since there are `2` red flowers and, therefore, `2!` ways to order them, we divide the total number of ways to arrange all the elements by `2!`.
`(3!)/(2!) = 3`
`R RY`
`YR R`
`RYR`
If we have `10` red flowers and `5` yellow flowers, then the total number of ways to arrange them is
`(15!)/(10!5!)`
If we have `r` red flowers, `y` yellow flowers, and `b` blue flowers, then the total number of ways to arrange them is
`((r+y+b)!)/(r!y!b!)`
Theorem: Say we have `n` objects which have one of `k` different types. Objects of the same type are considered identical. Label the types with numbers `1,2,...,k` and let `a_i` be the number of objects of type `i`. Then the number of ways to arrange the `n` objects is `(n!)/(a_1!a_2!...a_k!)`
The multinomial coefficient is
`((n),((a_1,a_2,...,a_k))) = (n!)/(a_1!a_2!...a_k!)`
The binomial coefficient is the multinomial coefficient for `k=2`, which is
`((n),((a_1,a_2)))`
It's often denoted by
`((n),(a_1))`
instead because we know `a_2 = n - a_1`
Sometimes, it's easier to count things by using some sort of encoding.
A word is a finite ordered sequence whose entries are drawn from some set `A`, called the alphabet
The length of a word is the number of entries it has
Entries may be repeated
An empty sequence `O/` is a word of length `0`
Example: Consider the alphabet `A = {a,b}`
The words of length `le 2` are:
`O/`
`a`
`b`
`aa`
`ab`
`ba`
`bb`
Theorem: If `|A| = n`, then the number of words of length `k` is `n^k`
There are `k` spots, and each spot has `n` choices of entries
So there are `ubrace(n*n*...*n)_k = n^k` words of length `k`
`[n] = {1,2,...,n}`
The number of subsets of `[n]` is `2^n`
Let `S sube [n]`
Define a word `w_s` of length `n` in the alphabet `{0,1}` as follows:
Let `i in [n]`
If `i in S`, then the `i^(th)` entry of `w_s = 1`
If `i notin S`, then the `i^(th)` entry of `w_s = 0`
If `n = 5` and `S = {1,3,4}`, then the word associated with `S` is `10110`
Define a function `f:{`subset `S` of `[n]} rarr {`word of length `n` in alphabet `{0,1}}`
We can define another function `g:{`words of length `n` in `{0,1}} rarr {`subset of `[n]}`
The process for converting a subset to a word is reversible, gives a unique result, and always gives a result with valid input
So `g` is the inverse of `f`, which means `f` is bijective
So `|{`subsets of `[n]}| = |{`words of length `n` in `{0,1}}| = 2^n`
The general idea is that any element is either in `S` or not in `S`
How many pairs of subsets `S,T sube [n]` satisfy `S sube T`?
Any element in `[n]` is
There are `3` choices for each of the `n` elements, so there are `3^n` total possibilities
In the context of words, the function would be
`f:{`pairs of subsets `S,T sube [n]` s.t. `S sube T} rarr {`words of length `n` in `{`in `S`, not in `S` but in `T`, not in `S` and not in `T}}`
For `n ge k` where `n` is a nonnegative integer, the falling factorial is
`(n)_k = n*(n-1)*(n-2)*...*(n-k+1)`
`(6)_3 = 6*5*4`
`(6)_6 = 6*5*4*3*2*1`
There are `k` numbers being multiplied
This can be seen by:
`(n)_k = n*(n-1)*(n-2)*...*(n-k+1)`
`= (n-0)*(n-1)*(n-2)*...*(n-(k-1))`
There are `k` numbers from `0` to `k-1`
Theorem: If `|A| = n ge k`, then there are `(n)_k` words of length `k` in `A` that do not have repeating entries
Let `sigma = a_1a_2...a_ka_(k+1)...a_n` be a permutation of `A`
The first `k` entries make up a word with no repeating entries
Since there are `n!` permutations, we have `n!` words with no repeating entries
But there are repeated words since the last `(n-k)` entries can be ordered in any way
So there are
`(n!)/((n-k)!) = (n*(n-1)*...*(n-k+1)*(n-k)!)/((n-k)!)`
`= n*(n-1)*...*(n-k+1)`
`= (n)_k`
words with no repeating entries
Let `A = {1,2,3,4,5}` and `k=3`
Let `sigma = 31254`
The first `k` entries are `312`, which is a word of length `k` with no repeating entries
So that is contained in `31254`
But that same word is also contained in `31245`
Intuitively, there are `n` choices for the first digit, `n-1` choices for the second digit, ..., `n-k+1` choices for the `k^(th)` digit
We saw earlier that the number of subsets of a set of size `n` is `2^n`. We could look at how many of those subsets are of size `k`.
Theorem: The number of `k`-element subsets of `[n]` is `((n),(k)) = (n!)/(k!(n-k)!)`
We can associate subsets of `[n]` with words of length `n` in `{0,1}`
The number of `k`-element subsets of `[n]` is the number of words of length `n` in `{0,1}` that have exactly `k` `1`'s
For such words, there are `k` ways to arrange the `1`'s and `n-k` ways to arrange the `0`'s
Which gives us `(n!)/(k!(n-k)!) = ((n),(k))`
Corollary: `sum_(k=0)^n ((n),(k)) = 2^n`
`sum_(k=0)^n ((n),(k))` is the number of ways to choose subsets of size `0`, `1`, `2`, ..., `n`
Well, that should make up all the possible subsets
Before, we showed that the total number of subsets is `2^n`
Pascal's Identity: `((n),(k-1)) + ((n),(k)) = ((n+1),(k))` for any `k ge 0`
`((n+1),(k))` is the number of `k`-element subsets of `[n+1]`
We could split those subsets up into two categories: subsets of size `k` that contain `n+1` and subsets of size `k` that don't contain `n+1`
The subsets of size `k` that don't contain `n+1` are actually the subsets of size `k` of `[n]`, so that gives us `((n),(k))`
If we look at the subsets of size `k` that do contain `n+1` and remove `n+1` from each subset, we end up with the number of subsets of size `k-1` of `[n]`, which gives us `((n),(k-1))`
These two sets don't overlap so there are `((n),(k))+((n),(k-1))` subsets of size `k` of `[n+1]`
Four of a Kind: `4` of the `5` cards have the same value
How many four of a kinds are there?
There are `13` choices for the value that is the same
There are `48` choices for the fifth card
Total number of ways to get a four of a kind: `13*48`
Alternatively,
There are `13` choices for the value that is the same
There are `12` choices for the value that is different
There are `4` choices for the suit of the different value
Total number of ways to get a four of a kind: `13*12*4`
Full House: `3` cards have the same value and `2` cards have the same value
How many full houses are there?
There are `13` choices for the value of the triple
There are `12` choices for the value of the pair
There are `((4),(3))` choices for the suits of the triple
There are `((4),(2))` choices for the suits of the pair
Total number of ways to get a full house: `13*12*((4),(3))*((4),(2))`
Two Pair: `2` cards have the same value, `2` cards have the same value, `1` card has a different value
How many two pairs are there?
There are `((13),(2))` choices for the value of each pair
There are `((4),(2))` choices for suits of one pair
There are `((4),(2))` choices for suits of other pair
There are `44` choices for the leftover card
Total number of ways to get a two pair: `((13),(2))*((4),(2))*((4),(2))*44`
Alternatively,
There are `((13),(2))` choices for the value of each pair
There are `11` choices for the value of the different card
There are `((4),(2))` choices for suits of one pair
There are `((4),(2))` choices for suits of other pair
There are `4` choices for the suit of the different card
Total number of ways to get a two pair: `((13),(2))*11*((4),(2))*((4),(2))*4`
Straight: `5` cards can be put in consecutive order by values
How many straights are there?
To pick values, we only need to know what the largest possible values are
The fifth card can be `5`, `6`, `7`, `8`, `9`, `10`, `J`, `Q`, `K`, or `A`
There are `10` choices for the fifth card
There are `4^5` choices for the suits of each card
Total number of ways to get a straight: `10*4^5`
Multisets are like subsets except the elements can be repeated.
Multisets of `{1,2,3}` of size `3` are:
`{1,1,1}`
`{1,1,2}`
`{1,1,3}`
`{1,2,2}`
`{1,2,3}`
`{1,3,3}`
`{2,2,2}`
`{2,2,3}`
`{2,3,3}`
`{3,3,3}`
Are these all the possible multisets? How can we be sure?
Let's add `1` to the second element and add `2` to the third element
`{1,1,1} rarr {1,2,3}`
`{1,1,2} rarr {1,2,4}`
`{1,1,3} rarr {1,2,5}`
`{1,2,2} rarr {1,3,4}`
`{1,2,3} rarr {1,3,5}`
`{1,3,3} rarr {1,4,5}`
`{2,2,2} rarr {2,3,4}`
`{2,2,3} rarr {2,3,5}`
`{2,3,3} rarr {2,4,5}`
`{3,3,3} rarr {3,4,5}`
Notice that we end up with all the subsets of size `3` of `[5]`. This leads to a more general result
Theorem: The number of `k`-element multisets of a set of size `n` is `((n+k-1),(k))`
Note: it doesn't matter what the set is, since we can form a bijection between the set and `[n]`
Let `S` be a multiset of size `k` of `[n]`
Sort the elements of `S` so that `s_1 le s_2 le s_3 le ... le s_k`
Add `i-1` to each `s_i`
Then we get `s_1 lt s_2 + 1 lt s_3 + 2 lt ... lt s_k + (k-1)`
Well, `{s_1, s_2+1, s_3+2, ..., s_k+(k-1)}` is a subset of size `k` of `[n+k-1]color(red)(text(*))`
The number of ways to make `k`-element subsets from a set of size `[n+k-1]` is `((n+k-1),(k))`
(Reversing the process -- subtracting `i-1` from each `s_i` -- shows that there is a bijection between `{s_1, s_2, ..., s_k}` and `{s_1, s_2+1, ..., s_k+(k-1)}`)
`color(red)(text(*))` happens when `s_k = n`
Let `x`,`y`,`z` be variables. The degree of the monomial `x^ay^bz^c` is `a+b+c` where `a,b,c ge 0`
How many monomials have degree `d`?
There are `3` with degree `1`:
`x,y,z`
There are `6` with degree `2`:
`x^2,y^2,z^2,xy,xz,yz`
There are `10` with degree `3`:
`x^3,y^3,z^3,x^2y,x^2z,y^2x,y^2z,z^2x,z^2y,xyz`
`x^ay^bz^c` is like a multiset of `{x,y,z}` where `x` appears `a` times, `y` appears `b` times, and `z` appears `c` times
Since they add up to `d`, there should be `d` total elements
So the total number of monomials is the number of multisets of size `d` of `{x,y,z}`, which is
`((d+3-1),(d)) = ((d+2),(d))`
Let `x_1,x_2,...,x_n` be variables. How many monomials `x_1^(a_1)*x_2^(a_2)*...*x_n^(a_n)` are there with degree `d`?
`x_1^(a_1)*x_2^(a_2)*...*x_n^(a_n)` is like a multiset of `{x_1,x_2,...,x_n}` where each `x_i` is chosen `a_i` times
Since they add up to `d`, there should be `d` total elements
So the total number of monomials is the number of multisets of size `d` of `{x_1,x_2,...,x_n}`, which is
`((n+d-1),(d))`
A weak composition of `n` into `k` parts is a `k`-tuple `(a_1,a_2,...,a_k)` such that each `a_i ge 0` and `a_1 + a_2 + ... + a_k = n`
A composition is the same except each `a_i gt 0`
`k` is the number of parts
Theorem: The number of weak compositions of `n` into `k` parts is `((n+k-1),(n))`
Claim: There is a bijection between weak compositions of `n` into `k` parts and `n`-element multisets of `[k]`
Given a weak composition `(a_1,...,a_k)`, we get a multiset that has the `i^(th)` element `a_i` times
Since `a_1 + ... + a_k = n`, this is an `n`-element multiset of `[k]`
Given an `n`-element multiset of `[k]`, let `a_i` be the number of times that `i` appears in the multiset
Then we end up with a weak composition `(a_1,...,a_k)` of `n`
Intuitively, a multiset is a weak composition that is written out. Since the parts of the weak composition have to add up to `n`, there are `n` elements in the multiset. So the formula for an `n`-element multiset applies here.
`((n+k-1),(n)) = ((n+k-1),(n+k-1-n)) = ((n+k-1),(k-1))`
How many ways are there to distribute `20` identical pieces of candy to `4` different children?
This can be seen as a weak composition of `20` into `4` parts
`((23),(20))`
How many ways can we distribute all the candy so that no child is candyless?
First, we can give each child `1` piece of candy
Now, we have `16` pieces of candy leftover which can be distributed in any way
So this can be seen as a weak composition of `16` into `4` parts
`((19),(16))`
Since each child has at least `1` candy, this is also a composition of `20` into `4` parts
Corollary: The number of compositions of `n` into `k` parts is `((n-1),(n-k))`
Generalizing the previous example, there is a bijection between compositions of `n` into `k` parts and weak compositions of `n-k` into `k` parts
`(((n-k)+k-1),(n-k)) = ((n-1),(n-k)) = ((n-1),(n-1-(n-k))) = ((n-1),(k-1))`
Corollary: The number of compositions of `n` into any number of parts is `2^(n-1)`
The possible number of parts for a composition of `n` ranges from `k = 1` to `k = n`
So the total number of compositions possible is
`sum_(k=1)^n((n-1),(k-1))`
`= sum_(k=0)^(n-1)((n-1),(k))`
Well, that is the formula for the number of subsets of `[n-1]`, which is `2^(n-1)`
A composition can be represented as `(1square1square...square1square1)` where we either put a `+` (plus sign) or a `,` (comma) in the boxes.
There are `n` `1's`, so there are `n-1` boxes
There are `2` choices for each box
So there are `2^(n-1)` total compositions
Let `X` be a set. A partition of `X` is an unordered collection of nonempty subsets `X_1,...,X_k` such that every element of `X` belongs to exactly one subset
An ordered partition of `X` is the same except each subset has an order
Each subset is a block of the partition
There are `5` partitions of `X = {1,2,3}`:
`k = 1:`
`{{1,2,3}}`
`k = 2:`
`{{1},{2,3}}`
`{{2},{1,3}}`
`{{3},{1,2}}`
`k = 3:`
`{{1},{2},{3}}`
For an unordered collection of subsets, `{{3},{1,2}}` and `{{1,2},{3}}` are the same (the order of the blocks doesn't matter)
How many ways are there to distribute `20` different pieces of candy to `4` identical children so that no child is candyless?
This can be seen as a partition of `[20]` into `4` blocks
Unfortunately, there's not really a nice formula for the number of set partitions of `[n]`. But we can still count them though.
Let `S(n,k)` be the number of partitions of a set of size `n` into `k` blocks
These are called Stirling numbers of the second kind
`S(0,0) = 1` and `S(n,k) = 0` if `k gt n`
For some values of `k`, there actually are nice formulas.
`S(n,1)`
This is `n` pieces into `1` block. The only way to do this is to put all the pieces into the block
`S(n,1) = 1`
`S(n,n)`
This is `n` pieces into `n` blocks. The only way to do this is to put each piece in each block
`S(n,n)=1`
`S(n,2)`
This is `n` pieces into `2` blocks
We can't put `O/` or the whole set in the blocks, so there are `2^n-2` complementary subsets
The order of the blocks don't matter, so there are `(2^n-2)/(2!) = 2^(n-1)-1` ways to do this
`S(n,2) = 2^(n-1)-1`
`S(n,n-1)`
This is `n` pieces into `n-1` blocks
One block must have `2` pieces, so we choose `2` elements to be in the same block
`S(n,n-1) = ((n),(2))`
For other values of `k`, there is a recurrence relation that allows us to calculate `S(n,k)`.
Theorem: If `k le n`, then `S(n,k) = S(n-1,k-1) + k*S(n-1,k)`
Consider two kinds of partitions of `[n]`
The first kind is partitions where `n` is in its own block
Removing that block, we end up with a partition of `n-1` into `k-1` blocks, which is `S(n-1,k-1)`
The second kind of partition is the partitions where `n` is not in its own block
Removing `n` from each partition, we end up with a partition of `n-1` into `k` blocks
But by doing so, we can't reconstruct the original situation because we don't know which block it came from
There are `k` blocks we could put `n` in `implies k` different ways to reconstruct the original situation
So the number of partitions is `k*S(n-1,k)`
Adding up both types of partitions gives us all the partitions of `[n]`
We can use this recurrence to verify that `S(n,2) = 2^(n-1)-1`
`S(n,2) = S(n-1,1) + 2*S(n-1,2)`
`= 1 + 2*S(n-1,2)`
`= 1 + 2*(2^(n-2)-1)`
`= 1 + 2^(n-1)-2`
`= 2^(n-1)-1`
The Stirling numbers counted the number of set partitions into blocks of specific sizes. To get the total number of set partitions of all sizes, we add them all up.
The Bell numbers are the number of partitions of `[n]` into any number of blocks
`B(n) = sum_(k=0)^nS(n,k)`
`B(0) = 1`
Theorem: `B(n+1) = sum_(i=0)^n ((n),(i)) B(i)`
Separate all the partitions of `[n+1]` based on the number of elements in the block that contains `n+1`
Consider those partitions where the block containing `n+1` is of size `j`
For the block containing `n+1`, there are `n` numbers to choose from and `j-1` spots, so there are `((n),(j-1))` ways to generate such a block
Now, there are `n+1-j` elements remaining
For the other blocks not containing `n+1`, they can be generated by looking at the number of partitions of `[n+j-1]`, i.e., `B(n+j-1)`
So the number of partitions where the block containing `n+1` is of size `j` is `((n),(j-1)) B(n+1-j)`
The possible sizes of blocks containing `n+1` range from `1` to `n+1`
`sum_(j=1)^(n+1) ((n),(j-1)) B(n+1-j)`
set `i = j-1`
`sum_(i=0)^n ((n),(i)) B(n-i)`
set `k = n-i`
`sum_(k=0)^n ((n),(n-k)) B(k)`
`sum_(k=0)^n ((n),(k)) B(k)`
A partition of `n` is a sequence of nonnegative integers `lambda_1 ge lambda_2 ge ... ge lambda_k ge 0` such that `lambda_1 + lambda_2 + ... + lambda_k = n`
`lambda = (lambda_1, lambda_2, ..., lambda_k)` is a partition
`|lambda| = lambda_1 + lambda_2 + ... + lambda_k`
`l(lambda)` is the length of the partition
There are no nice formulas for the number of partitions, but we have a notation for it.
`p(n) = ` number of partitions of `n`
`p_k(n) = ` number of partitions of `n` such that `l(lambda) = k` (has `k` parts)
`p(5) = 7`
`(5)`
`(4,1)`
`(3,2)`
`(3,1,1)`
`(2,2,1)`
`(2,1,1,1)`
`(1,1,1,1,1)`
Partitions can be represented using Young diagrams. The `i^(th)` row has `lambda_i` boxes.
`lambda = (4,2,1)`
The transpose (or conjugate) of a partition `lambda` is the partition `lambda^T` whose Young diagram is `Y(lambda)` flipped across the main diagonal
`(lambda^T)^T = lambda`
`lambda_i^T = {j|lambda_j ge i}`
`lambda^T = (3,2,1,1)`
`lambda` is self-conjugate if `lambda = lambda^T`
Some self-conjugate partitions are `(4,3,2,1)`, `(5,1,1,1,1)`, `(4,2,1,1)`
Theorem: The number of partitions `lambda` of `n` with `l(lambda) le k` equals the number of partitions `mu` of `n` with `mu_i le k`
Example: `n=5, k=2`
`(5)`
`(4,1)`
`(3,2)`
`(1,1,1,1,1)`
`(2,1,1,1)`
`(2,2,1)`
Notice that taking the transpose of `lambda` gives us `mu`
Claim: There is a bijection between `A = {`partitions `lambda` of `n` with `l(lambda) le k}` and `B = {`partitions `mu` of `n` such that `mu_i le k}`
Let `f:A rarr B` be a function defined to be `f(lambda) = lambda^T`
Since `(lambda^T)^T = lambda`, `f circ f` is the identity function, which means it is its own inverse
So `f` is bijective `implies |A| = |B|`
Theorem: The number of self-conjugate partitions `lambda` of `n` equals the number of partitions `mu` of `n` with only odd and distinct parts
Start with a Young diagram of `lambda`
Take the boxes of the first row and column and put them all in a row
Make that row the first row of `mu`
Repeat this for all the rows/columns of the `lambda`
(Informally, peel off the outer layer of `lambda` and straighten it out to become a row in `mu`)
This process is reversible, so there is a bijection
(Informally, fold the row of `mu` in half and make it the outer layer of `lambda`)
Since `lambda` is self-conjugate, there are an odd number of parts in the `i^(th)` row and column
Now we show why they are distinct
We can come up with a formula for the length of the `i^(th)` row
The `i^(th)` row of `mu` is the `i^(th)` row of `lambda` minus the boxes to the left plus the `i^(th)` row of `lambda^T` minus the boxes from the top minus `1` for the box in the top-left corner
`mu_i = lambda_i-(i-1) + lambda_i^T - (i-1) - 1`
`= 2lambda_i - 2i + 1`
Claim: `mu_1 gt mu_2 gt ...`
`mu_i = 2lambda_i - 2i + 1`
`mu_(i+1) = 2lambda_(i+1) - 2(i+1) + 1`
Since `lambda` is a partition, `lambda_i ge lambda_(i+1)`
So
`mu_i = 2lambda_i - 2i + 1`
`ge 2lambda_(i+1)-2i-1 = mu_(i+1)`
The twelvefold way considers all the ways to put `k` balls into `n` boxes. Putting balls into boxes can be thought of as a function `f:[k] rarr [n]`.
The balls and boxes can be distinguishable or indistinguishable. If the balls are distinguishable, each of them has a different color. If the balls are indistinguishable, they all have the same color. If the boxes are distinguishable, each box is labeled with a different number.
The function can be arbitrary, injective, or surjective. If the function is arbitrary, then there are no restrictions on which balls can go in which box. If the function is injective, then each box can have at most one ball (no box can have two or more balls). If the function is surjective, then each box has to have at least one ball.
Considering all the possible combinations, we get the following table:
balls/boxes | `f` arbitrary | `f` injective | `f` surjective |
distinguishable/distinguishable | `(1)` | `(2)` | `(3)` |
indistinguishable/distinguishable | `(4)` | `(5)` | `(6)` |
distinguishable/indistinguishable | `(7)` | `(8)` | `(9)` |
indistinguishable/indistinguishable | `(10)` | `(11)` | `(12)` |
If the balls are distinguishable, then it is important to know which ball goes where. If the balls are indistinguishable, then we only need to know how many balls are in each box.
`(1)`: balls and boxes are distinguishable; `f` is arbitrary
For each of the `k` balls, there are `n` choices for which box it can be put in
So there are `n^k` ways
`(2)`: balls and boxes are distinguishable; `f` is injective
For the first ball, there are `n` choices of boxes
For the second ball, there are `n-1` choices of boxes
`vdots`
For the `k^(th)` ball, there is `(n-k+1)` choices of boxes
So there are `(n)_k = n(n-1)(n-2)...(n-k+1)` ways
`(3)`: balls and boxes are distinguishable; `f` is surjective
Some boxes might have one ball. Some boxes might have more than one ball. But none of them are empty
This is like breaking up `[k]` into `n` blocks
The number of ways to do this are counted by the number of set partitions of `[k]` into `n` blocks, which is `S(k,n)`
Since the boxes are distinguishable, the order of the partitions matter
So there are `n!S(k,n)` ways
`(4)`: balls are indistinguishable, boxes are distinguishable; `f` is arbitrary
Since the balls are indistinguishable, we're not concerned with which balls go to which box. We only need to know how many balls are in each box
Let `a_i` be the number of balls in box `i`
Then `a_1 + a_2 + ... a_n = k` where each `a_i ge 0`
This is a weak composition of `k` into `n` parts
So there are `((k+n-1),(k))` ways
`(5)`: balls are indistinguishable, boxes are distinguishable; `f` is injective
Since the balls are indistinguishable, we're not concerned with which balls go to which box. We only need to know how many balls are in each box
Additionally, since each box can only get at most one ball, we only need to know which box gets a ball
This is like choosing a subset of `k` boxes that get a ball
So there are `((n),(k))` ways
`(6)`: balls are indistinguishable, boxes are distinguishable; `f` is surjective
Since the balls are indistinguishable, we're not concerned with which balls go to which box. We only need to know how many balls are in each box
Let `a_i` be the number of balls in box `i`
Then `a_1 + a_2 + ... a_n = k` where each `a_i gt 0` since each box must have a ball
This is a composition of `k` into `n` parts
So there are `((k-1),(n-1))` ways
`(7)`: balls are distinguishable, boxes are indistinguishable; `f` is arbitrary
Some boxes might have one ball. Some boxes might have more than one ball. Some boxes might be empty
This is like breaking up `[k]` into at most `n` blocks, since each box might not have a ball
So there are `sum_(i=1)^nS(k,i)` ways
`(8)`: balls are distinguishable, boxes are indistinguishable; `f` is injective
Since the boxes are indistinguishable, we can rearrange the boxes in any order
Therefore, it doesn't matter where the balls go (putting the same ball in different boxes doesn't count as a separate ordering because we can just rearrange the boxes)
So there's really only one way to do this
However, since each box can have at most one ball, if there are more balls than boxes, then it is impossible
So the number of ways is `{(1\ if k le n),(0\ if k gt n):}`
`(9)`: balls are distinguishable, boxes are indistinguishable; `f` is surjective
Some boxes might have one ball. Some boxes might have more than one ball. But none of them are empty
This is like breaking up `[k]` into exactly `n` blocks, since each box must have a ball
The number of ways to do this are counted by the number of set partitions of `[k]` into `n` blocks, which is `S(k,n)`
So there are `S(k,n)` ways
`(10)`: balls and boxes are indistinguishable; `f` is arbitrary
Since the balls are indistinguishable, we're not concerned with which balls go to which box. We only need to know how many balls are in each box
Since the boxes are indistinguishable, we can rearrange them after we put the balls in them so that they're in decreasing order (with respect to the number of balls in each box)
This is like integer partitions of `k` into at most `n` parts, since each box might not have a ball
So there are `sum_(i=1)^np_i(k)` ways
`(11)`: balls and boxes are indistinguishable; `f` is injective
Since the boxes are indistinguishable, we can rearrange the boxes in any order
Therefore, it doesn't matter where the balls go (it doesn't matter anyway since the balls are indistinguishable)
So there's really only one way to do this
However, since each box can have at most one ball, if there are more balls than boxes, then it is impossible
So the number of ways is `{(1\ if k le n),(0\ if k gt n):}`
`(12)`: balls and boxes are indistinguishable; `f` is surjective
Since the balls are indistinguishable, we're not concerned with which balls go to which box. We only need to know how many balls are in each box
Since the boxes are indistinguishable, we can rearrange them after we put the balls in them so that they're in decreasing order (with respect to the number of balls in each box)
This is like integer partitions of `k` into exactly `n` parts, since each box must have a ball
So there are `p_n(k)` ways
So the twelvefold way table looks like:
balls/boxes | `f` arbitrary | `f` injective | `f` surjective |
distinguishable/distinguishable | `n^k` | `(n)_k` | `n!S(k,n)` |
indistinguishable/distinguishable | `((k+n-1),(k))` | `((n),(k))` | `((k-1),(n-1))` |
distinguishable/indistinguishable | `sum_(i=1)^nS(k,i)` | `{(1\ if k le n),(0\ if k gt n):}` | `S(k,n)` |
indistinguishable/indistinguishable | `sum_(i=1)^np_i(k)` | `{(1\ if k le n),(0\ if k gt n):}` | `p_n(k)` |
The binomial theorem provides a formula for expanding powers of `x+y`.
Theorem: `(x+y)^n = sum_(i=0)^n ((n),(i)) x^iy^(n-i)` for `n ge 0`
Consider the expansion `(x+y)^n = ubrace((x+y)(x+y)...(x+y))_n`
Multiply the terms, considering all the possible choices in each set of parentheses
Some terms will be repeated. For example, `x*x*x*...*x*y` and `x*x*y*x*...*x` both have `n-1` `x's` and `1` `y`
The number of repeated terms is the number of ways to create a term that has that form
The form of each term will be `i` `x's` and `n-i` `y's`
Which gives us `((n),(i))` ways to create `x^iy^(n-i)`
To get the final answer, we sum up all the possible products
The sum goes from `0` to `n` because we have situations where `x` appears `0` times and `x` appears `n` times
There are several identities that can be obtained by substituting values for `x` and `y`.
Let `x=y=1`
Then we get `2^n = sum_(i=0)^n ((n),(i))`, which was proven earlier
Let `x=-1`, `y=1`
Then we get `0 = sum_(i=0)^n (-1)^i((n),(i))`
There's an interesting result when we expand the sum:
`((n),(0))-((n),(1))+((n),(2))-((n),(3))+...+(-1)^n((n),(n)) = 0`
`((n),(0))+((n),(2))+... = ((n),(1))+((n),(3))+...`
`sum_(i text( even)) ((n),(i)) = sum_(i text( odd)) ((n),(i))`
This means the number of subsets with even size equals the number of subsets with odd size
So there are `(2^n)/2 = 2^(n-1)` subsets with even size (and likewise for subsets with odd size)
We can also obtain another identity by taking the derivative.
Applying `del/(delx)`, we get
`n(x+y)^(n-1) = sum_(i=0)^n i ((n),(i))x^(i-1)y^(n-i)`
`= sum_(i=1)^n i ((n),(i)) x^(i-1)y^(n-i)`
Setting `x=y=1`, we get
`n2^(n-1)=sum_(i=1)^n i ((n),(i))`
The right-hand side counts the number of ways to pick a subset `S` of `[n]` and an element `x` in that subset:
`|{(x,S)|S sube [n], x in S}|`
First, pick a subset `S` of size `i`: `((n),(i))` ways to to this
Then, pick an element `x` in `S`: `i` ways to to this
This is like picking members to be in a group, then picking a leader
The left-hand side tells a similar story
First, pick an element `x` to put in the subset `S`: `n` ways to do this
Then, pick the remaining elements to put in the subset `S`: `2^(n-1)` ways to do this
This is like picking a leader, then the group members
The multinomial theorem is a generalization of the binomial theorem.
For `n,k ge 0`,
`(x_1+x_2+...+x_k)^n = sum_(((a_1,a_2,...,a_k))) ((n),((a_1, a_2, ..., a_k))) x_1^(a_1)x_2^(a_2)...x_k^(a_k)`
where `a_i ge 0` and `a_1 + ... + a_k = n`
The proof is similar to the proof for the binomial theorem
The number of times `x_1^(a_1)x_2^(a_2)...x_k^(a_k)` appears is equal to the number of ways to choose each `x_i` exactly `a_i` times, which is `((n),((a_1,a_2,...,a_k)))`
Example: `(x_1+x_2+x_3)^3`
`= ((3),((3,0,0)))x_1^3 + ((3),((0,3,0)))x_2^3 + ((3),((0,0,3)))x_3^3`
`+ ((3),((2,1,0)))x_1^2x_2 + ((3),((2,0,1)))x_1^2x_3 + ((3),((1,2,0)))x_1x_2^2`
`+ ((3),((0,2,1)))x_2^2x_3 + ((3),((1,0,2)))x_1x_3^2 + ((3),((0,1,2)))x_2x_3^2`
`+ ((3),((1,1,1)))x_1x_2x_3`
`= x_1^3+x_2^3+x_3^3+3x_1^2x_2+3x_1^2x_3+3x_1x_2^2+3x_2^2x_3+3x_1x_3^2+3x_2x_3^2+6x_1x_2x_3`
`k^n = sum_(((a_1,...,a_k))) ((n),((a_1,...,a_k)))`
Set `x_1 = x_2 = ... = x_k = 1`
`0 = sum_(((a_1,...,a_k))) (1-k)^(a_1) ((n),((a_1,...,a_k)))`
Set `x_1 = 1-k`, `x_2 = ... = x_k = 1`
`nk^(n-1) = sum_(((a_1,...,a_k))) a_1 ((n),((a_1,...,a_k)))`
Apply `del/(delx_1)` and set `x_1 = ... = x_k = 1`
A formal power series is a way to encode a sequence of numbers as an algebraic object. The numbers are the coefficients of some (infinite) polynomial.
A formal power series (in variable `x`) is an expression of the form `sum_(n=0)^(oo) a_nx^n = A(x)` where `a_n` are scalars
Alternatively, it can be written as `sum_(n ge 0) a_nx^n`
Let `[x^n]A(x) = a_n` be the coefficient of `x^n`
Some special cases of formal power series are polynomials and scalars. Polynomials are formal power series where all the terms after a certain point are zero. Scalars are formal power series where `a_0` is a scalar and the rest of the terms are zero.
Two power series are equal if and only if all of their coefficients match
`A(x) = B(x)` if and only if `[x^n]A(x) = a_n = b_n = [x^n]B(x)` for all `n`
Let `A(x) = sum_(n ge 0) a_nx^n` and `B(x) = sum_(n ge 0) b_nx^n`
The sum of two formal power series is
`A(x)+B(x) = sum_(n ge 0) (a_n+b_n)x^n`
The product of two formal power series is
`A(x)B(x) = sum_(n ge 0) c_nx^n` where `c_n = sum_(i=0)^n a_ib_(n-i)`
(the indices have to add up to `n`)
Addition and multiplication are both commutative
`A(x)+B(x) = B(x)+A(x)`
`A(x)B(x) = B(x)A(x)`
and associative
`A(x)+[B(x)+C(x)] = [A(x)+B(x)]+C(x)`
`A(x)[B(x)C(x)] = [A(x)B(x)]C(x)`
Example: Let `A(x) = B(x) = sum_(n ge 0) x^n`
`A(x)+B(x) = sum_(n ge 0) 2x^n`
`A(x)B(x) = sum_(n ge 0) (n+1)x^n`
In the multiplication, `c_n = sum_(i=0)^n a_ib_(n-i) = sum_(i=0)^n 1 = n+1`
`A(x)` is invertible if there exists `B(x)` such that `A(x)B(x) = 1`
Then `B(x) = A(x)^(-1) = 1/(A(x))`
An example of an invertible formal power series:
Let `A(x) = sum_(n ge 0) x^n`, `B(x) = 1-x`
`A(x)B(x) = sum_(n ge 0) c_nx^n` where `c_n = sum_(i=0)^n a_ib_(n-i)`
If `n=0`, then `c_0 = a_0b_0 = 1`
If `n=1`, then `c_1 = a_0b_1 + a_1b_0 = (1)(-1) + (1)(1) = 0`
If `n ge 2`, then `c_n = 0` since `B(x)` has no degree `ge 2` term
So `c_n = 1` when `n=0` and `c_n = 0` when `n gt 0` `implies A(x)B(x) = sum_(n ge 0) c_nx^n = 1`
This means `sum_(n ge 0) x^n` is invertible with inverse `1-x`
We can also see that their product is equal to `1` by manually multiplying them:
`(1+x+x^2+x^3+...)(1-x)`
`= 1+x+x^2+x^3+...`
`\ \ \ \ \ \ \ \ -x-x^2-x^3-...`
`= 1`
From this result, we get an identity:
`(sum_(n ge 0) x^n)(1-x) = 1`
`sum_(n ge 0) x^n = 1/(1-x)`
Theorem: `A(x)` is invertible if and only if `[x^0]A(x) != 0`
A formal power series is invertible if and only if the constant term is nonzero
`(lArr)`Suppose `[x^0]A(x) != 0`. Want to show `A(x)` is invertible
Consider `B(x) = sum_(n ge 0) b_nx^n` and try to pick `b_n` so that `A(x)B(x) = 1`
Expanding out the equation `A(x)B(x) = 1` and matching coefficients, we get:
`a_0b_0 = 1`
`(a_1b_0 + a_0b_1)x = 0x`
`(a_2b_0 + a_1b_1 + a_0b_2)x^2 = 0x^2`
`vdots`
Using this system of equations, we can try to find `b_n`
`a_0b_0 = 1 implies b_0 = 1/a_0`
`a_1b_0+a_0b_1 = 0 implies b_1 = -(a_1b_0)/a_0 = -a_1/(a_0)^2`
`a_2b_0+a_1b_1+a_0b_2 = 0 implies b_2 = -(a_2b_0+a_1b_1)/a_0`
`vdots`
At each stage, it is possible to find `b_(n+1)` since it is in terms of `b_0,...,b_n`. More formally, we can do so using induction. Suppose we have solved for `b_0, ..., b_n`. At each stage, we have
`a_(n+1)b_0 + ... + a_0b_(n+1) = 0`
So we can solve for `b_(n+1) = -(a_(n+1)b_0 + ...)/a_0`
`(implies)`If the constant term is `0`, then the equation `a_0b_0 = 1` has no solution `implies` cannot find `b_n` `implies` `A(x)` is not invertible
Intuitively, if a formal power series has no constant term, then its product with any other power series will always be a sum of powers of `x`, which can never be equal to `1`
Let `A(x),B(x)` be formal power series such that `[x^0]A(x) = 0`
The composition `(B circ A)(x) = B(A(x))` is defined by `sum_(n ge 0) b_nA(x)^n`
It looks like we're taking the sum of infinitely many things, so how is this operation well defined, i.e., how are we going to get an answer if it looks like we're adding infinitely many things?
Since `A(x)` has no constant term, we have
`A(x) = a_1x + a_2x^2 + ...`
What happens when we take powers of `A(x)`? For `A(x)^2`, there is no constant term. There is also no linear term
`A(x)^2 = a_1^2x^2 + 2a_2a_1x^3 + ...`
Claim: `[x^i]A(x)^n = 0` for `i lt n`
Expanding `sum_(n ge 0) b_nA(x)^n`, we get
`b_0 + b_1A(x) + b_2A(x)^2 + b_3A(x)^3 + ...`
`= b_0`
`+ b_1a_1x + b_1a_2x^2 + b_1a_3x^3 + ...`
`+ b_2a_1^2x^2 + b_2 2a_2a_1x^3 + ...`
To get the coefficient of `x^n`, we only have to do a finite amount of additions. For example,
The coefficient of `x^0` is `b_0`
The coefficient of `x^1` is `b_1a_1x`
The coefficient of `x^2` is `b_1a_2x^2 + b_2a_1^2x^2`
So we will get an answer from doing this operation
If `A(x)` had a constant term, then we would end up having to do an infinite amount of additions
Example: Let `A(x) = x^d` where `d gt 0` and `B(x) = sum_(n ge 0) x^n`
`B(A(x)) = sum_(n ge 0) (x^d)^n = sum_(n ge 0) x^(dn)`
We can substitute this into the identity `(1-x)sum_(n ge 0) x^n = 1` to get a new identity:
`(1-x^d)sum_(n ge 0) x^(dn) = 1`
`1/(1-x^d) = sum_(n ge 0) x^(dn)`
The derivative of `A`, written as `DA` or `A'`, is defined by `sum_(n ge 1) na_nx^(n-1) = sum_(n ge 0) (n+1)a_(n+1)x^n`
The familiar rules for derivatives apply to formal power series as well
`D(A+B) = DA + DB`
`D(A*B) = (DA)*B + A*(DB)` (product rule)
`D(B circ A) = (DA)(DB circ A)` (chain rule)
`D(A^(-1)) = -(DA)/A^2`
`D(A^n) = n(DA)A^(n-1)`
From before, `1/(1-x) = sum_(n ge 0) x^n`. We can use this identity to get a new identity by taking the derivative:
`1/(1-x)^2 = sum_(n ge 1) nx^(n-1) = sum_(n ge 0) (n+1)x^n`
It is possible to simplify `sum_(n ge 0) nx^n`:
`sum_(n ge 0) nx^n = sum_(n ge 1)nx^n = x sum_(n ge 1) nx^(n-1)` (we can pull out an `x` because there's no constant term)
`= x sum_(n ge 0) (n+1)x^n`
`= x*1/(1-x)^2`
`= x/(1-x)^2`
or
`sum_(n ge 0) nx^n = sum_(n ge 0) (n+1)x^n - sum_(n ge 0) x^n`
`= 1/(1-x)^2 - 1/(1-x)`
`= (1-(1-x))/(1-x)^2`
`= x/(1-x)^2`
In either case, we get the identity
`(1-x)^2 sum_(n ge 0) nx^n = x`
`sum_(n ge 0) nx^n = x/(1-x)^2`
The previous binomial theorem only considered nonnegative powers. Here, we consider real-numbered powers.
Let `m` be a real number and `k ge 0` be an integer
`((m),(0))=1`
`((m),(k)) = (m(m-1)(m-2)...(m-k+1))/(k!)`
Theorem: `(1+x)^m = sum_(n ge 0) ((m),(n)) x^n`
Consider `-1` as a power: `m=-1`
From before,
`1/(1-x) = sum_(n ge 0) x^n`
Substituting `-x` for `x`,
`1/(1+x) = sum_(n ge 0) (-x)^n = sum_(n ge 0) (-1)^nx^n`
Using the binomial theorem, we should get the same result
From the binomial theorem: `(1+x)^(-1) = sum_(n ge 0) ((-1),(n))x^n`
`((-1),(n)) = ((-1)(-2)(-3)...(-1-n+1))/(n!)`
`= ((-1)^n n!)/(n!)`
`= (-1)^n`
So the equation obtained from the binomial theorem matches the one from the formal power series
Consider any negative power: `m=-d` where `d gt 0` is an integer
We could try to see what it evaluates to without using the binomial theorem, but it gets pretty complicated
`(1+x)^(-d) = (1/(1+x))^d`
`= (sum_(n ge 0) (-1)^nx^n)^d`
Using the binomial theorem: `(1+x)^(-d) = sum_(n ge 0) ((-d),(n)) x^n`
`((-d),(n)) = ((-d)(-d-1)(-d-2)...(-d-n+1))/(n!)`
`= (-1)^n((d)(d+1)(d+2)...(d+n-1))/(n!)`
`= (-1)^n((d-1)!(d)(d+1)...(d+n-1))/((d-1)!n!)`
`= (-1)^n((d+n-1)!)/((d-1)!n!)`
`= (-1)^n((d+n-1),(n))`
So `(1+x)^(-d) = 1/(1+x)^d = sum_(n ge 0) (-1)^n((d+n-1),(n))x^n`
If we substitute `-x` for `x`, we get
`(1-x)^(-d) = 1/(1-x)^d = sum_(n ge 0) (-1)^n((d+n-1),(n))(-x)^n = sum_(n ge 0) ((d+n-1),(n))x^n`
Consider a fractional power: `m=1/2`
`(1+x)^(1/2)` is a formal power series whose square is `(1+x)`
Using the binomial theorem: `(1+x)^(1/2) = sum_(n ge 0) ((1/2),(n))x^n`
`((1/2),(n)) = ((1/2)(-1/2)(-3/2)...(-1/2-n+1))/(n!)`
`= (-1)^(n-1)((1/2)(1/2)(3/2)(5/2)...((2n-1)/2))/(n!)`
`= (-1)^(n-1)(3*5*7*...*2n-1)/(2^n n!)`
which doesn't really simplify further (unless we introduce the double factorial)
However, this means we've found the square root of a formal power series
`(sum_(n ge 0) ((1/2),(n))x^n)^2 = 1+x`
Given a quadratic equation, `A(x)t^2+B(x)t+C(x) = 0` where `A(x),B(x),C(x)` are formal power series, the solutions `t` are given by the quadratic formula
`t = (-B(x) +- sqrt(B(x)^2-4A(x)C(x)))/(2A(x))`
if `A(x)` is invertible
Ordinary generating functions are a way to encode a sequence of numbers as a formal power series.
Given a sequence of numbers `a_0, a_1, a_2, ...`, the ordinary generating function (ogf) is
`A(x) = sum_(n ge 0) a_nx^n`
We can use ordinary generating functions to find closed formulas for linear recurrence relations.
A sequence `a_0,a_1,...` satisfies a linear recurrence relation (of order `d`) if there exist scalars `c_1, c_2, ..., c_d` such that `c_d != 0` and for all `n ge d`
`a_n = c_1a_(n-1)+c_2a_(n-2)+...+c_da_(n-d)`
`d` is the minimum number of initial conditions that must be specified in order to find `a_n`
An example of a linear recurrence relation is the Fibonacci numbers
`1,1,2,3,5,8,13,21,...`
The relation is `a_n = a_(n-1)+a_(n-2)` for `n ge 2`
It satisifes a linear recurrence relation of order `2` where `c_1=c_2=1`
We have a recurrence relation for `a_n`, but it would be nice to find a closed formula for `a_n` so we could calculate `a_n` directly without going through the recurrence.
Consider the case when `d=1`
Then we have `a_n = c_1a_(n-1)` for `n ge 1`
`a_1=c_1a_0`
`a_2=c_1a_1=c_1^2a_0`
`a_3=c_1a_2=c_1^3a_0`
`vdots`
`a_n=c_1^na_0`
Here, `a_0` is an initial condition
Consider the case when `d=2`
Then we have `a_n = c_1a_(n-1)+c_2a_(n-2)` for `n ge 2` and `c_2 != 0`
The characteristic polynomial of this recurrence relation is defined to be
`t^2-c_1t-c_2`
The roots `r_1,r_2` are given by
`(c_1 +- sqrt(c_1^2+4c_2))/2`
So the characteristic polynomial can be factored as
`t^2-c_1t-c_2 = (t-r_1)(t-r_2)`
Theorem: If `r_1 != r_2`, then there are constants `alpha_1,alpha_2` such that `a_n = alpha_1r_1^n+alpha_2r_2^n` for all `n`
Given `a_0, a_1, ...`, create the ordinary generating function `A(x) = sum_(n ge 0)a_nx^n`
We can rewrite `A(x)` as
`a_0 + a_1x + sum_(n ge 2)a_nx^n`
The recurrence is only valid for `n ge 2` so we have to take out the first two terms in order to make the substitution below
From the definition of a linear recurrence relation, `a_n = c_1a_(n-1)+c_2a_(n-2)`, so
`A(x) = a_0 + a_1x + sum_(n ge 2)(c_1a_(n-1)+c_2a_(n-2))x^n`
`= a_0 + a_1x + c_1sum_(n ge 2)a_(n-1)x^n+c_2sum_(n ge 2)a_(n-2)x^n`
The last two summations are almost the same as `A(x)`:
`sum_(n ge 2)a_(n-1)x^n=xsum_(n ge 2)a_(n-1)x^(n-1)=x(a_1x+a_2x^2+a_3x^3+...)=x(A(x)-a_0)`
`sum_(n ge 2)a_(n-2)x^n=x^2sum_(n ge 2)a_(n-2)x^(n-2)=x^2sum_(n ge 0)a_nx^n=x^2A(x)`
Plugging these two back into `A(x)`, we get
`A(x) = a_0+a_1x+c_1x(A(x)-a_0)+c_2x^2A(x)`
`= a_0+a_1x+c_1xA(x)-c_1a_0x+c_2x^2A(x)`
Now we gather all the `A(x)`'s onto one side:
`A(x)-c_1xA(x)-c_2x^2A(x)=a_0+a_1x-a_0c_1x`
`A(x)(1-c_1x-c_2x^2)=a_0+a_1x-a_0c_1x`
We can divide both sides by `(1-c_1x-c_2x^2)` since it is invertible (because there is a constant term):
`A(x)=(a_0+a_1x-a_0c_1x)/(1-c_1x-c_2x^2)`
We can factor the bottom by using `t^2-c_1t-c_2 = (t-r_1)(t-r_2)` and plugging in `1/x` for `t`:
`x^(-2)-c_1x^(-1)-x_2=(1/x-r_1)(1/x-r_2)`
To make it look like `1-c_1x-c_2x^2`, we multiply by `x^2`:
`1-c_1x-c_2x^2=(1-r_1x)(1-r_2x)`
Knowing that the denominator can be factored, we can use partial fraction decomposition to get
`A(x)=(a_0+a_1x-a_0c_1x)/(1-c_1x-c_2x^2)=alpha_1/(1-r_1x)+alpha_2/(1-r_2x)`
for some constants `alpha_1,alpha_2`
Both of those terms are geometric series `color(red)(text(*))`, so we can write
`A(x)=alpha_1/(1-r_1x)+alpha_2/(1-r_2x)=alpha_1sum_(n ge 0)(r_1x)^n+alpha_2sum_(n ge 0)(r_2x)^n`
`= alpha_1sum_(n ge 0) r_1^nx^n + alpha_2sum_(n ge 0) r_2^nx^n`
The coefficient of `x^n` on the left-hand side is `a_n`
The coefficient of `x^n` on the right-hand side is `alpha_1r_1^n+alpha_2r_2^n`
So `a_n = alpha_1r_1^n+alpha_2r_2^n`
`color(red)(text(*))`this also comes from the identity `1/(1-x) = sum_(n ge 0)x^n`
To solve for `alpha_1,alpha_2`, plug in `n=0,1`
`a_0=alpha_1+alpha_2`
`a_1=alpha_1r_1+alpha_2r_2`
(`a_0` and `a_1` are part of the numbers in the sequence that is given)
This theorem can be seen with the Fibonacci numbers
They are defined by `a_n = a_(n-1)+a_(n-2)`, so the characteristic polynomial is `t^2-t-1`
The roots are `r_1 = (1+sqrt(5))/2` and `r_2 = (1-sqrt(5))/2`
According to the theorem, there exist `alpha_1, alpha_2` such that `a_n = alpha_1((1+sqrt(5))/2)^n+alpha_2((1-sqrt(5))/2)^n`
To find `alpha_1,alpha_2`, plug in `n=0,1`
`1=alpha_1+alpha_2`
`1=alpha_1((1+sqrt(5))/2)+alpha_2((1-sqrt(5))/2)`
Solving this system of equations, we get
`alpha_1=(1+sqrt(5))/(2sqrt(5))`
`alpha_2=-(1-sqrt(5))/(2sqrt(5))`
So `a_n = (1+sqrt(5))/(2sqrt(5))((1+sqrt(5))/2)^n-(1-sqrt(5))/(2sqrt(5))((1-sqrt(5))/2)^n`
`= 1/sqrt(5)((1+sqrt(5))/2)^(n+1)-1/sqrt(5)((1-sqrt(5))/2)^(n+1)`
Theorem: If `r_1=r_2`, then there are constants `alpha_1,alpha_2` such that `a_n = alpha_1r_1^n+nalpha_2r_1^n`
The proof is the same up until partial fraction decomposition
At that point, we have
`A(x) = alpha_1/(1-r_1x)+alpha_2/(1-r_1x)^2`
`alpha_1/(1-r_1x)` is a geometric series so that simplifies to `alpha_1sum_(n ge 0)r_1^nx^n color(red)(text(*))`
`alpha_2/(1-r_1x)^2` is the square of a geometric series so that simplifies to `alpha_2sum_(n ge 0)(n+1)r_1^nx^n color(red)(text(**))`
Comparing the coefficients of `x^n`, we get
`a_n = alpha_1r_1^n + alpha_2(n+1)r_1^n`
`= (alpha_1+alpha_2)r_1^n + alpha_2nr_1^n`
`color(red)(text(*))`this also comes from the identity `1/(1-x) = sum_(n ge 0)x^n`
`color(red)(text(**))`this also comes from the identity `1/(1-x)^2 = sum_(n ge 0)(n+1)x^n`
So the procedure for finding closed formulas for a linear recurrence relation of order `2` is:
For general `d`, we have
`a_n=c_1a_(n-1)+c_2a_(n-2)+...+c_da_(n-d)` for `n ge d`
The characteristic polynomial is
`t^d-c_1t^(d-1)-c_2t^(d-2)-...-c_d = (t-r_1)(t-r_2)...(t-r_d)`
If all `r_1,r_2,...,r_d` are different, then there exist constants `alpha_1,alpha_2,...,alpha_d` such that
`a_n=alpha_1r_1^n+alpha_2r_2^n+...+alpha_dr_d^n`
What if some roots are the same?
Example: `d=5`, `r_1=r_2=r_3`, `r_4=r_5`, `r_1 != r_4`
Then there exist constants `alpha_1,alpha_2,alpha_3,alpha_4,alpha_5` such that
`a_n=alpha_1r_1^n+nalpha_2r_1^n+n^2alpha_3r_1^n+alpha_4r_4^n+nalpha_5r_4^n`
Ordinary generating functions sometimes make counting things easier.
We can think of `a_n` as counting the number of "structures" on the set `[n]`.
If `a_n = n!`, then `a_n` is the number of ways to order the elements in `[n]`
If `b_n = 2^n`, then `b_n` is the number of ways to pick a subset of `[n]`
`A(x)=sum_(n ge 0) a_nx^n` is an ogf encoding the number of orderings
`B(x)=sum_(n ge 0) b_nx^n` is an ogf encoding the number of subsets
In general, `a_n` is the number of ways of putting structure `alpha` on the set `[n]` and `b_n` is the number of ways of putting structure `beta` on the set `[n]`.
So `a_n+b_n` is the number of ways of putting structure `alpha` on the set `[n]` or putting structure `beta` on the set `[n]`. `(A+B)(x)` is an ogf encoding the number of ways of putting either `alpha` on `[n]` or `beta` on `[n]`.
In the above example, `a_n+b_n=n!+2^n` is the number of ways to pick either an ordering of the elements of `[n]` or a subset of `[n]`
`a_n+a_n=(2n)!` can be thought of as the number of ways of letting either person `1` order the elements of `[n]` or person `2` order the elements of `[n]`
The product is putting two structures on the elements of `[n]` simultaneously.
`A(x)B(x) = sum_(n ge 0) c_nx^n` where `c_n = sum_(i=0)^n a_ib_(n-i)`
`c_n=a_ib_(n-i)` is the number of ways to put structure `alpha` on `{1,...,i}` and to put structure `beta` on `{i+1,...,n}`
So `c_n` is the number of ways of splitting `[n]` into two consecutive pieces and putting `alpha` on the first piece and putting `beta` on the second piece
Example: A class has `n` days. We want to split the course into two portions, where the first portion is theory and the second portion is labs. One of the theory lectures is given by a guest lecturer and two of the lab days are carried out by the guest lecturer. How many ways are there to design the course?
Let `alpha` be picking the theory portion, `beta` be picking the lab portion
So `a_i = i` is the number of ways to pick one theory day out of `i` days to be the guest speaker
And `b_j = ((j),(2))` is the number of ways to pick two lab days out of `j` days to be the guest speaker
In terms of generating functions, we have
`A(x) = sum_(n ge 0)a_nx^n = sum_(n ge 0)nx^n = x/(1-x)^2`
`B(x) = sum_(n ge 0)b_nx^n = sum_(n ge 0)((n),(2))x^n = x^2/(1-x)^3 color(red)(text(*))`
`C(x) = A(x)B(x) = (x/(1-x)^2)(x^2/(1-x)^3) = x^3/(1-x)^5`
The coefficients of `C(x)` will be the answer to this question
`sum_(n ge 0) c_nx^n = x^3/(1-x)^5`
To do that, we can use the binomial theorem:
`x^3 sum_(n ge 0) ((-5),(n))x^n`
`= x^3 sum_(n ge 0) ((n+4),(n))x^n`
`= sum_(n ge 0) ((n+4),(n))x^(n+3)`
We want the coefficient of `x_n`, so we plug in `n-3`:
`= sum_(n ge 0) ((n+1),(n-3))x^n`
So `c_n = ((n+1),(n-3))`
`color(red)(text(*))`To get this identity, we expand `((n),(2))`:
`sum_(n ge 0) ((n),(2))x^n = sum_(n ge 0) (n(n-1))/2x^n`
`= 1/2 sum_(n ge 0) n(n-1)x^n`
We can find a formula for that by taking the derivative of `sum_(n ge 0)x^n = 1/(1-x)` twice and then multiplying by `x^2/2`:
`sum_(n ge 0)x^n = 1/(1-x)`
`sum_(n ge 0)nx^(n-1) = 1/(1-x)^2`
`sum_(n ge 0)n(n-1)x^(n-2) = 2/(1-x)^3`
`x^2/2sum_(n ge 0)n(n-1)x^(n-2) = x^2/2 2/(1-x)^3`
`1/2sum_(n ge 0)n(n-1)x^n = x^2/(1-x)^3`
We can get this answer without using generating functions
We can determine the class structure by knowing
Let `a,b,c,d in [n]` be the days that these occur
Day `1` can be a day for the guest speaker
`1 le a`
The last day of the theory portion can be any day after the guest speaker (including day `1`)
`1 le a le b`
The first day that the guest speaker leads the lab portion cannot be day `1`
`1 le a le b lt c`
The second day that the guest speaker leads the lab has to be different from the first
`1 le a le b lt c lt d`
The second day that the guest speaker leads the lab can be the last day of the class
`1 le a le b lt c lt d le n`
This is the same situation as
`0 le a lt b lt c lt d le n`
So the problem becomes choosing `4` numbers from `n+1` numbers, which is `((n+1),(4))`
Note that `((n+1),(n-3)) = ((n+1),(n+1-n+3)) = ((n+1),(4))`
Example: Let `p_(le k)(n)` be the number of integer partitions of `n` using `le k` parts
Note: After taking the transpose, `p_(le k)(n)` is also the number of integer partitions of `n` where all parts are `le k`
We want a simple formula for `sum_(n ge 0) p_(le k)(n)x^n`
For `k=1`, it is the number of partitions where all parts are `le 1`. To do this, we just repeat `1` `n` times
`p_(le 1)(n) = 1` for all `n`
So the generating function is
`sum_(n ge 0) p_(le 1)(n)x^n = sum_(n ge 0)x^n = 1/(1-x)`
For `k=2`, it is the number of partitions using only `1`'s and `2`'s. This is the same as splitting `[n]` into two consecutive pieces, and then splitting the first piece into consecutive pieces of size `1` and splitting the second piece into consecutive pieces of size `2`
Example: `7 = 1+1+1+2+2`
The first piece is `1|2|3` and the second piece is `4\ 5|6\ 7`
Let `alpha` be breaking up a set into singletons, `beta` be breaking up a set into consecutive `2`-element subsets
Let `a_n` be the number of ways to do `alpha` to `[n]`, `b_n` be the number of ways to do `beta` to `[n]`
There's only one way to split a set into singletons, so `a_n = 1`
To split a set into consecutive `2`-element subsets, `n` has to be even. If it is, then there is one way to to do this, so `b_n = {(1 text( if n even)),(0 text( if n odd)):}`
The product of the generating functions will give us what we want:
`sum_(n ge 0) p_(le 2)(n)x^n = (sum_(n ge 0)a_nx^n)(sum_(n ge 0)b_nx^n)`
`= (sum_(n ge 0)x^n)(sum_(n ge 0)x^(2n))`
`= 1/(1-x)*1/(1-x^2)`
`= 1/((1-x)(1-x^2))`
Another way to see how `sum_(n ge 0)p_(le 2)(n)x^n = 1/((1-x)(1-x^2))`:
`1/((1-x)(1-x^2)) = (1+x+x^2+x^3+...)(1+x^2+x^4+x^6+...)`
`= (1+x^1+x^(1+1)+x^(1+1+1)+...)(1+x^2+x^(2+2)+x^(2+2+2)+...)`
Multiplying these two expressions, we get the following table:
`1` | `x^1` | `x^(1+1)` | `x^(1+1+1)` | |
`1` | `1` | `x^1` | `x^(1+1)` | `x^(1+1+1)` |
`x^2` | `x^2` | `x^(1+2)` | `x^(1+1+2)` | `x^(1+1+1+2)` |
`x^(2+2)` | `x^(2+2)` | `x^(1+2+2)` | `x^(1+1+2+2)` | `x^(1+1+1+2+2)` |
`x^(2+2+2)` | `x^(2+2+2)` | `x^(1+2+2+2)` | `x^(1+1+2+2+2)` | `x^(1+1+1+2+2+2)` |
The result is that the exponents are partitions where are parts are `le 2`. The coefficient of `x^n` is the number of partitions of `n` where all parts are `le k`, i.e., `p_(le k)(n)`
For `k=3`, we have
`sum_(n ge 0) p_(le 3)(n)x^n = 1/((1-x)(1-x^2)(1-x^3))`
For general `k`, we have
`sum_(n ge 0) p_(le k)(n)x^n = 1/(1-x)*1/(1-x^2)*...*1/(1-x^k)`
`= prod_(i=1)^k 1/(1-x^i)`
Taking `k rarr oo`, we get
`p_(le oo)(n) = p(n)`
which is the number of partitions of `n` where all parts are `le oo`, which is the same as the number of partitions of `n`
So we have
`sum_(n ge 0)p(n)x^n = prod_(i=1)^(oo) 1/(1-x^i) = 1/((1-x)(1-x^2)(1-x^3)...)`
It looks like we're taking the product of infinitely many things. So how is this well defined, i.e., how do we get an answer? Expanding the product, we get
`1/((1-x)(1-x^2)(1-x^3)...) = (1+x+x^2+x^3+...)(1+x^2+x^4+x^6+...)(1+x^3+x^6+x^9+...)`
To multiply it all out, we choose one term from each set of parentheses and multiply all the terms together. We do this for all powers of `x`
For `x^0`, we're forced to pick all `1`'s from each set of parentheses so the product will be `1`
For `x^1`, we have to pick one `x` from the first set of parentheses and `1`'s from the rest
For `x^2`, we have to pick an `x^2` from a set of parentheses and `1`'s from the rest
For `x^3`, we have to pick an `x^3` or `x` and `x^2` and `1`'s from the rest
This process repeats infinitely, but each step only requires a finite amount of multiplications to calculate the coefficient of `x^n`
Example: Let `p_(text(odd))(n)` be the number of partitions of `n` where all parts are odd and let `p_(text(dist))(n)` be the number of partitions of `n` where all parts are distinct
`n` | `p_(text(odd))(n)` | `p_(text(dist))(n)` |
`1` | `(1)` | `(1)` |
`2` | `(1,1)` | `(2)` |
`3` | `(3)`,`(1,1,1)` | `(3)`,`(2,1)` |
`4` | `(3,1)`,`(1,1,1,1)` | `(4)`,`(3,1)` |
`5` | `(5)`,`(3,1,1)`,`(1,1,1,1,1)` | `(5)`,`(4,1)`,`(3,2)` |
We can use generating functions to show that these two are the same number
Theorem: `p_(text(odd))(n)` = `p_(text(dist))(n)`
Using generating functions, the goal is to show that `sum_(n ge 0)p_(text(odd))(n)x^n = sum_(n ge 0)p_(text(dist))(n)x^n`
From the previous example, we have
`sum_(n ge 0)p_(text(odd))(n)x^n = (1/(1-x))(1/(1-x^3))(1/(1-x^5))...`
For `p_(text(dist))(n)x^n`, we can only use unique exponents, so we have
`sum_(n ge 0)p_(text(dist))(n)x^n = (1+x)(1+x^2)(1+x^3)(1+x^4)...`
`1+x^k` can be rewritten as
`1+x^k = (1-x^(2k))/(1-x^k)`
So `p_(text(dist))(n)x^n` can be rewritten as
`sum_(n ge 0)p_(text(dist))(n)x^n = (1-x^2)/(1-x)*(1-x^4)/(1-x^2)*(1-x^6)/(1-x^3)*(1-x^8)/(1-x^4)*...`
All the terms in the numerator will cancel out the terms in the denominator with even exponents. What's left is the odd terms
`= 1/(1-x)*1/(1-x^3)*1/(1-x^5)*...`
`= sum_(n ge 0)p_(text(odd))(n)x^n`
We compose ordinary generating functions when we want to break up `[n]` into consecutive intervals, apply a structure on each interval, and then apply another structure on a set of those intervals.
`a_n` is the number of ways to apply structure `alpha` on a set of size `n` and `a_0=0`. `h_n` is the number of ways to break `[n]` into consecutive intervals and place structure `alpha` on each interval. The generating functions are `A(x) = sum_(n ge 0) a_nx^n` and `H(x) = sum_(n ge 0) h_nx^n`.
Theorem: `H(x) = 1/(1-A(x))`
`A(x)^k` is the ordinary generating function for the number of ways to break up `[n]` into `k` consecutive intervals and place structure `alpha` on each piece
This is counted by `h_n` when we sum over all `k`
So `H(x) = sum_(k ge 0) A(x)^k = 1/(1-A(x))`
Example: There are `n` soldiers in a line and we want to split the line at several places to form teams of soldiers. Also, we want to assign a leader to each team. How many ways are there to do this?
Let `a_n` be the number of ways to pick a leader from `n` people. Then `a_n = n`
`A(x) = sum_(n ge 0) a_nx^n = sum_(n ge 0)nx^n = x/(1-x)^2`
The answer is given by `h_n`
`H(x) = 1/(1-A(x)) = 1/(1-x/(1-x)^2)`
`= (1-x)^2/((1-x)^2-x)`
`= (1-2x+x^2)/(1-3x+x^2)`
Using partial fractions, we get
`h_n = 1/sqrt(5)((3+sqrt(5))/2)^n-1/sqrt(5)((3-sqrt(5))/2)^n`
So far, we broke `[n]` into consecutive intervals and applied a structure to each interval. We could apply another structure `beta` on a subset of those intervals.
`b_n` is the number of structures of type `beta` on a set of size `n`. The generating function is `B(x) = sum_(n ge 0) b_nx^n`. Now `h_n` is the number of ways to break `[n]` into consecutive intervals, place structure `alpha` on each interval, then place structure `beta` on a subset of those intervals.
Theorem: `H(x) = B(A(x))`
`b_kA(x)^k` is the ordinary generating function for the number of ways to break up `[n]` into `k` consecutive intervals, place structure `alpha` on each piece, and then place structure `beta` on the `k` pieces
This is counted by `h_n` when we sum over all `k`
So `H(x) = sum_(k ge 0) b_kA(x)^k = B(A(x))`
Going back to the soldier example, suppose we want to additionally pick some of the teams for night duty. How many ways are there to do this?
Let `b_n` be the number of ways to pick some teams for night duty. This is the same as picking a subset, so `b_n = 2^n`
`B(x) = sum_(n ge 0) b_nx^n = sum_(n ge 0) 2^nx^n = sum_(n ge 0) (2x)^n = 1/(1-2x)`
From before, `A(x) = x/(1-x)^2`
The number of ways to do this is counted by `h_n`
`H(x) = B(A(x)) = 1/(1-(2x)/(1-x)^2)`
`= (1-x)^2/((1-x)^2-2x)`
`= (1-2x+x^2)/(1-4x+x^2)`
Using partial fractions, we would get our answer
We could get the answer without using generating functions
Each soldier could be
The only exception is the first soldier who only has two choices
So there are two choices for the first soldier and three choices for the rest of the `n-1` soldiers
The number of ways is `2*3^(n-1)`
Catalan numbers can be used to count a lot of things. One way to view them is the number of ways to balance `n` pairs of parentheses.
Let `C_n` be the number of ways to write a balanced expression using `n` pairs of parentheses
For example, for `n=3`
`()()()`
`(())()`
`((()))`
`(()())`
`()(())`
`C_n` is also the same as the number of words with `n` left parentheses and `n` right parentheses such that every initial segment has at least as many `(` as `)`
`C_n` is also the same as the number of sequences of `n` counts of `+1`'s and `n` counts of `-1`'s such that every initial partial sum is `ge 0`
There is some kind of recursive structure to these parentheses. For example, we can have a balanced pair of parentheses and put another pair of balanced parentheses inside. We can use this recursive structure to obtain a recurrence relation. It turns out that the recurrence relation will be nonlinear.
Lemma: If `n ge 0`, then `C_n = sum_(i = 0)^(n-1)C_iC_(n-1-i)`
Every expression starts with a `(` and is matched by some `)`
In between those `()`, we can put another set of balanced parentheses
After the `)`, we can put another set of balanced parentheses
These choices are independent of each other, so there are `C_iC_(n-1-i)` total choices
Since `i` can go from `0` to `n-1`, we have `sum_(i = 0)^(n-1)C_iC_(n-1-i)`
So we have a recurrence relation for the Catalan numbers. Now we can try to find a closed formula for `C_n` using generating functions. In this case, we can define the generating function `C(x) = sum_(n ge 0) C_nx^n` where `C_0 = 1`.
We start by multiplying both sides of the recurrence relation by `x^n`
`C_nx^n = sum_(i = 0)^(n-1)C_iC_(n-1-i)x^n`
And then summing over all positive `n`
`sum_(n gt 0)C_nx^n = sum_(n gt 0) sum_(i = 0)^(n-1)C_iC_(n-1-i)x^n`
The left-hand side is `C(x)` without the `n=0` term (which is `C_0 = 1`), so the left-hand side evaluates to `C(x)-1`
The right-hand side looks like the result of multiplying two generating functions
`C(x)^2 = sum_(n ge 0) (sum_(i=0)^nC_iC_(n-i))x^n` by the definition of multiplying two generating functions
`sum_(n gt 0) sum_(i = 0)^(n-1)C_iC_(n-1-i)x^n` almost looks like `C(x)^2`. We can manipulate it so that it does
Since `n gt 0`, we can pull out an `x` from `C(x)^2`
`x sum_(n gt 0) sum_(i=0)^(n-1)C_iC_(n-1-i)x^(n-1)`
Then we can re-index to get
`x sum_(n ge 0) sum_(i=0)^n C_iC_(n-i)x^n`
`= xC(x)^2`
So the right-hand side evaluates to `xC(x)^2`
Which gives us
`C(x)-1=xC(x)^2`
`xC(x)^2-C(x)+1=0`
This tells us that `C(x)` is a solution to a quadratic equation `xt^2-t+1=0`. We can use the quadratic formula to solve for `t = C(x)`, which gives us
`t = (1 +- sqrt(1-4x))/(2x)`
There are two possibilities for `t = C(x)`:
There's only one correct choice for `C(x)`, so which one do we pick? Looking at `2xC(x)`, whatever `C(x)` is, when we multiply it with `2x`, there will be no constant term. So `1+sqrt(1-4x)` must not have a constant term either
The constant term of `1+sqrt(1-4x)` is `1` plus whatever the constant term of `sqrt(1-4x)` is, which we can find by using the binomial theorem:
`(1-4x)^(1/2) = sum_(n ge 0) ((1/2),(n)) (-4x)^n`
The constant term appears when `n=0`, so `((1/2),(0))=1` is the constant term
So `C(x) = (1-sqrt(1-4x))/(2x)`
Alternatively, looking at `2xC(x) = 1-sqrt(1-4x)`, if we plug in `x=0` on the left-hand side, we get `0`. So plugging in `x=0` on the right-hand side should give us `0` too
`1+sqrt(1-4*0)`
`= 1+sqrt(1)`
`= 1+1 = 2`
`1-sqrt(1-4*0)`
`= 1-sqrt(1)`
`= 1-1 = 0`
So we pick the expression with the negative sign
To simplify this, we can use the binomial theorem (again):
`(1-4x)^(1/2) = sum_(n ge 0) ((1/2),(n))(-4x)^n`
We can simplify this by expanding `((1/2),(n))`:
`((1/2),(n)) = ((1/2)(-1/2)(-3/2)...(1/2-n+1))/(n!)`
So we have
`sum_(n ge 0) ((1/2),(n))(-4x)^n = sum_(n ge 0) ((1/2)(-1/2)(-3/2)...(1/2-n+1))/(n!) (-4)^n x^n`
`= sum_(n ge 0) (1/2)^n (1(-1)(-3)...(1-2n+2))/(n!) (-4)^n x^n`
`= sum_(n ge 0) (-2)^n (1(-1)(-3)...(-2n+3))/(n!) x^n`
`= -sum_(n ge 0) 2^n (1*1*3*...*(2n-3))/(n!) x^n`
`= -sum_(n ge 0) 2^n (1*1*3*...*(2n-3))/(n!) * (2*4*6*...*(2n-2))/(2*4*6*...*(2n-2)) x^n`
`= -sum_(n ge 0) 2^n ((2n-2)!)/(n!) * 1/(2*4*6*...*(2n-2)) x^n`
`= -sum_(n ge 0) 2 ((2n-2)!)/(n!) * 1/(1*2*3*...*(n-1)) x^n`
`= -2sum_(n ge 0) ((2n-2)!)/(n!(n-1)!) x^n`
So `(1-4x)^(1/2) = -2sum_(n ge 0) ((2n-2)!)/(n!(n-1)!) x^n`
Since we're looking for `C(x)`,
`C(x) = (1-(1-4x)^(1/2))/(2x)`
`= 1/(2x)(1-(1-4x)^(1/2))`
`= 1/(2x)(1+2sum_(n ge 0) ((2n-2)!)/(n!(n-1)!) x^n)`
`= 1/(2x)(1-1+2sum_(n ge 1) ((2n-2)!)/(n!(n-1)!) x^n)` (taking out the constant term)
`= sum_(n ge 1) ((2n-2)!)/(n!(n-1)!) x^(n-1)`
`= sum_(n ge 1) ((2(n-1))!)/(n!(n-1)!) x^(n-1)`
`= sum_(n ge 0) ((2n)!)/((n+1)!n!) x^n`
So `C(x) = sum_(n ge 0) ((2n)!)/((n+1)!n!) x^n` and `C_n = ((2n)!)/((n+1)!n!)`, which looks like a binomial coefficient after pulling out `1/(n+1)`:
`C_n = 1/(n+1)((2n)!)/(n!n!)`
`= 1/(n+1)((2n),(n))`
Other Catalan objects for `n=3`
1) The number of ways to apply binary operation `text(*)` to `n+1` inputs
`a text(*) (b text(*) (c text(*) d))`
`a text(*) ((b text(*) c) text(*) d)`
`(a text(*) b) text(*) (c text(*) d)`
`((a text(*) b) text(*) c) text(*) d`
`(a text(*) (b text(*) c)) text(*) d`
(Look at 2) first)
Let `alpha_n` be the number of ways to apply binary operation `text(*)` to `n+1` inputs
There's a bijection between 1) and 2)
Place a `text(*)` inside each node
From the bottom, combine leaves into one expression with `text(*)`
To go the other way, start with the outermost `text(*)` and make that the root
Make the left and right part subtrees
So `alpha_n = beta_n = C_n`
2) The number of rooted binary trees with `n+1` leaves
Let `beta_n` be the number of ways to form a rooted binary tree with `n+1` leaves
Remove the root to form two trees (left and right)
The left part has `i` leaves, so there are `beta_(i-1)` ways to do this
The right part has `n+1-i` leaves, so there are `beta_(n-i)` ways to do this
The left part needs to have at least one leaf and the right part also needs to have at least one leaf, so `1 le i le n`
`beta_n = sum_(i=1)^n beta_(i-1)beta_(n-i) = sum_(i=0)^(n-1)beta_ibeta_(n-1-i)`
So `beta_n` satisifies the same recurrence as the Catalan numbers
3) The number of forward paths from `(0,0)` to `(n,n)` which do not go above the line `x=y`
Let `gamma_n` be the number of forward paths from `(0,0)` to `(n,n)` which do not go above the line `x=y`
There is a bijection between 3) and the Catalan numbers
A right step corresponds to a `(` and a step up corresponds to a `)`
So `gamma_n = C_n`
The forward paths also satisify the recurrence relation
Given a path, let `i` be the smallest positive value such that `(i,i)` is on `x=y`
Chop the path into two pieces
The first piece is the path from `(0,0)` to `(i,i)` which does not touch `x=y` except at the endpoints
The second piece is the path from `(i,i)` to `(n,n)`
So the total number of paths is `gamma_n = sum_(i=1)^ngamma_(i-1)gamma_(n-i) = sum_(i=0)^(n-1)gamma_(i)gamma_(n-1-i)`
`gamma_n` satisifies the same recurrence as the Catalan numbers
Exponential generating functions are similar to ordinary generating functions. They're still formal power series, but they encode sequences differently. As such, the interpretations of operations, such as multiplication and composition, have different meanings and can be used for different applications of problems.
For example, when using ordinary generating functions, we were constrained to consecutive intervals. But it may be more natural to form groups where the elements are not consecutive. Exponential generating functions give us a way to do that.
Given a sequence `a_0, a_1, a_2, ...`, the exponential generating function (egf) is
`A(x) = sum_(n ge 0) a_n/(n!)x^n`
When `a_n=1` for all `n`, we use `e^x` to denote `sum_(n ge 0) 1/(n!)x^n`
Taking the derivative (bringing down an `n`) is like shifting the sequence by one
`A(x) = sum_(n ge 0) a_n/(n!)x^n`
`A(x) = a_0 + sum_(n ge 1) a_n/(n!)x^n`
`A'(x) = sum_(n ge 1) (na_n)/(n!)x^(n-1)`
`A'(x) = sum_(n ge 1) a_n/((n-1)!)x^(n-1)`
`A'(x) = sum_(n ge 0) a_(n+1)/(n!)x^n`
Example: Suppose we have a sequence defined by `a_0 = 1` and `a_n = n(a_(n-1)-n+2)` for `n ge 1`
Let's try to encode it as an ordinary generating function
So let `A(x) = sum_(n ge 0)a_nx^n` be the ogf
Multiplying the recurrence by `x^n` and summing over all `n ge 1`, we get
`sum_(n ge 1)a_nx^n = sum_(n ge 1)(na_(n-1)-n^2+2n)x^n`
`A(x)-a_0 = sum_(n ge 1)na_(n-1)x^n + sum_(n ge 1)(-n^2+2n)x^n`
`A(x)-a_0 = xsum_(n ge 1)na_(n-1)x^(n-1) + sum_(n ge 1)(-n^2+2n)x^n`
`A(x)-a_0 = xsum_(n ge 0)na_nx^n + sum_(n ge 1)(-n^2+2n)x^n`
`A(x)-a_0 = x^2A'(x) + sum_(n ge 1)(-n^2+2n)x^n`
Now we have a differential equation, which would be too complicated to deal with
Instead, let's try to encode this sequence as an exponential generating function
So let `A(x) = sum_(n ge 0) a_n/(n!)x^n` be the egf
We could substitute in the recurrence after changing the summation to `n ge 1` (by pulling out the constant term)
`A(x) = sum_(n ge 0)a_n/(n!)x^n`
`= a_0 + sum_(n ge 1)a_n/(n!)x^n`
`= 1 + sum_(n ge 1)(na_(n-1)-n(n-2))/(n!)x^n`
`= 1 + sum_(n ge 1)(na_(n-1))/(n!)x^n - sum_(n ge 1)(n(n-2))/(n!)x^n`
`= 1 + sum_(n ge 1)a_(n-1)/((n-1)!)x^n - sum_(n ge 1)(n-2)/((n-1)!)x^n`
`= 1 + xsum_(n ge 1)a_(n-1)/((n-1)!)x^(n-1) - xsum_(n ge 1)(n-2)/((n-1)!)x^(n-1)`
`= 1 + xsum_(n ge 0)a_n/(n!)x^n - xsum_(n ge 0)(n-1)/(n!)x^n`
`= 1 + xA(x) - xsum_(n ge 0)n/(n!)x^n + xsum_(n ge 0) 1/(n!)x^n`
`= 1 + xA(x) - xsum_(n ge 1)1/((n-1)!)x^n + xe^x`
`= 1 + xA(x) - x^2sum_(n ge 1)1/((n-1)!)x^(n-1) + xe^x`
`= 1 + xA(x) - x^2sum_(n ge 0)1/(n!)x^n + xe^x`
`= 1 + xA(x) - x^2e^x + xe^x`
So we have
`A(x) = 1 + xA(x) - x^2e^x + xe^x`
`A(x) - xA(x) = 1 - x^2e^x + xe^x`
`A(x)(1-x) = 1 - x^2e^x + xe^x`
`A(x) = (1 - x^2e^x + xe^x)/(1-x)`
`= 1/(1-x) + ((x-x^2)e^x)/(1-x)`
`= 1/(1-x) + (x(1-x)e^x)/(1-x)`
`= 1/(1-x) + xe^x`
`= sum_(n ge 0)x^n + xsum_(n ge 0)1/(n!)x^n`
`= sum_(n ge 0)x^n + sum_(n ge 0)1/(n!)x^(n+1)`
`= sum_(n ge 0)x^n + sum_(n ge 1)1/((n-1)!)x^n`
Normally for ordinary generating functions, we would get our answer `a_n` by looking at the coefficient of `x^n`. However, with exponential generating functions, we have `sum_(n ge 0)a_n/(n!)x^n`. So the summations have to be in that form before we can extract the coefficient
`= sum_(n ge 0)(n!)/(n!)x^n + sum_(n ge 1)n/(n!)x^n`
`= 1 + sum_(n ge 1)(n!)/(n!)x^n + sum_(n ge 1)n/(n!)x^n`
`= 1 + sum_(n ge 1)(n!+n)/(n!)x^n`
So `a_n = n!+n`
The product of two exponential generating functions can be thought of as putting a structure on a subset of `[n]` and putting another structure on the complement.
Let `alpha, beta` be structures on sets. Let `a_n` be the number of ways to do `alpha` on a set of size `n`. Let `b_n` be the number of ways to do `beta` on a set of size `n`. Let `c_n` be the number of ways to pick a subset `S sube [n]`, put `alpha` on `S` and put `beta` on `[n]\\S`.
Then `sum_(n ge 0)c_n/(n!)x^n = (sum_(n ge 0)a_n/(n!)x^n)(sum_(n ge 0)b_n/(n!)x^n)`.
More generally, we can handle more than two structures. If we had `k` structures, the product of their egf's is the egf for the number of ways to write `[n] = S_1 uu S_2 uu ... uu S_k` such that no subsets overlap and we put the `i^(th)` structure on `S_i`.
Let `A(x) = sum_(n ge 0)a_n/(n!)x^n` and `B(x) = sum_(n ge 0) b_n/(n!)x^n`
Lemma: `A(x)B(x) = sum_(n ge 0) c_n/(n!)x^n` where `c_n = sum_(i=0)^n ((n),(i)) a_ib_(n-i)`
The coefficient of `x^n` in `A(x)B(x)` is `sum_(i=0)^na_i/(i!)b_(n-i)/((n-i)!)` by the definition of multiplying two power series
But it is also equal to `c_n/(n!)`
`c_n/(n!) = sum_(i=0)^n(a_ib_(n-i))/(i!(n-i)!)`
`c_n = sum_(i=0)^n(n!a_ib_(n-i))/(i!(n-i)!)`
`c_n = sum_(i=0)^n((n),(i))a_ib_(n-i)`
Let `a_n` be the number of structures of type `alpha` on a set of size `n`
Let `b_n` be the number of structures of type `beta` on a set of size `n`
Then `((n),(i))a_ib_(n-i)` is the number of ways to pick a subset `S sube [n]` of size `i`, putting structure `alpha` on `S`, and putting structure `beta` on `[n]\\S`
So `c_n` is the number of ways to pick subsets (possibly empty) of `[n]`, putting structure `alpha` on `S`, and putting structure `beta` on `[n]\\S`
Example: There are `n` football players and we want to split them up into two groups. Both groups will be assigned an ordering, but the each player in the second group also gets to choose one of three colors for their uniforms. How many ways are there to do this?
Let `alpha` be the ways to order a set. So `a_n = n!`
Let `beta` be the ways to order a set and assign a color to each element. So `b_n = 3^n n!`
`A(x) = sum_(n ge 0)a_n/(n!)x^n = sum_(n ge 0)x^n = 1/(1-x)`
`B(x) = sum_(n ge 0)b_n/(n!)x^n = sum_(n ge 0)3^nx^n = 1/(1-3x)`
`C(x) = A(x)B(x) = 1/(1-x)*1/(1-3x)`
Using partial fractions, we get
`1/(1-x)*1/(1-3x) = (3/2)/(1-3x)-(1/2)/(1-x)`
`= 3/2sum_(n ge 0)3^nx^n - 1/2sum_(n ge 0)x^n`
`= 3/2sum_(n ge 0)(3^n n!)/(n!)x^n - 1/2sum_(n ge 0)(n!)/(n!)x^n`
So `c_n = 3/2 3^n n! - 1/2 n!`
There's a trick for getting rid of odd/even terms of a formal power series `A(x) = sum_(n ge 0)a_nx^n`
To get rid of all odd terms, add `A(-x)` and divide the sum by `2`:
`A(x)+A(-x) = sum_(n ge 0)a_nx^n + sum_(n ge 0)(-1)^na_nx^n`
When `n` is odd, the terms will cancel each other out, so there are only even terms leftover
When `n` is even, the terms will be added, so we need to divide by `2`
`(A(x)+A(-x))/2 = sum_(n ge 0)a_(2n)x^(2n)`
To get rid of all even terms, subtract `A(-x)` and divide the difference by `2`:
`A(x)-A(-x) = sum_(n ge 0)a_nx^n - sum_(n ge 0)(-1)^na_nx^n`
When `n` is even, the terms will cancel each other out, so there are only odd terms leftover
When `n` is odd, the terms will be added, so we need to divide by `2`
`(A(x)-A(-x))/2 = sum_(n ge 0)a_(2n+1)x^(2n+1)`
Example: There are `n` distinguishable telephone poles and we want to paint each of them either red or blue. But the number of blue poles must be even. How many ways are there to do this?
Let `R(x)` be the egf for painting `n` poles red. There's only one way to paint `n` poles red, so `R(x) = sum_(n ge 0)1/(n!)x^n = e^x`
Let `B(x)` be the egf for painting `n` poles blue. There's only one way to paint `n` poles blue if `n` is even and zero ways if `n` is odd, so `B(x) = sum_(n ge 0)1/((2n)!)x^(2n) = (e^x+e^(-x))/2`
`sum_(n ge 0)c_n/(n!)x^n = R(x)B(x) = e^x((e^x+e^(-x))/2)`
`= (e^(2x)+1)/2`
`= 1/2e^(2x) + 1/2`
`= 1/2 sum_(n ge 0) 1/(n!)(2x)^n + 1/2`
`= 1/2 sum_(n ge 0) 2^n/(n!)x^n + 1/2`
`= sum_(n ge 0) 2^(n-1)/(n!)x^n + 1/2`
`= 1 + sum_(n ge 1) 2^(n-1)/(n!)x^n`
So `c_0 = 1` and `c_n = 2^(n-1)`
We can get this answer without using generating functions
If we knew which poles were blue, then we automatically know which ones are red too
So all we need to do is pick a subset of even size of `n`
There are `2^(n-1)` subsets of even size of `n`
We can use the product of egf's to get an egf for the Stirling numbers.
Define `a_n=1` if `n ge 0` and `a_0=0`
We can interpret this as counting the number of ways for a set to be nonempty
`A(x) = sum_(n ge 0)a_n/(n!)x^n = sum_(n ge 1)x^n/(n!) = e^x-1`
`A(x)^2 = sum_(n ge 0)c_n/(n!)x^n`
`c_n` is the number of ways to pick a subset `S sube [n]` such that `S != O/` and `[n]\\S != O/`
The Stirling numbers, `S(n,k)`, counted the number of ways to break up a set of size `n` into `k` nonempty pieces without regard to order. In this case, `k=2` and the order matters. `S` is like the first subset and `[n]\\S` is like the second subset. So this is ordered set partitions with two blocks, the number of which is counted by `2!S(n,2)`
But `c_n` is also the number of ordered set partitions of `[n]` into `2` blocks. So `c_n = 2!S(n,2)`
Plugging that back into `A(x)^2`, we get
`A(x)^2 = sum_(n ge 0)c_n/(n!)x^n = sum_(n ge 0)(2!S(n,2))/(n!)x^n`
But `A(x)^2` is also equal to `(e^x-1)^2`, so we get
`sum_(n ge 0)(2!S(n,2))/(n!)x^n = (e^x-1)^2`
`(e^x-1)^2` is the exponential generating function for ordered set partitions into two blocks
Dividing by `2!`, we also get
`sum_(n ge 0)(S(n,2))/(n!)x^n = (e^x-1)^2/(2!)`
`(e^x-1)^2/(2!)` is the exponential generating function for set partitions into two blocks, i.e., `S(n,2)`
For general `k`, if we take `A(x)^k`, then that would be counting the number of ways to break `[n]` into `k` nonempty subsets, which is exactly the number of ordered set partitions into `k` blocks
So more generally,
`(e^x-1)^k = sum_(n ge 0)(k!S(n,k))/(n!)x^n`
`(e^x-1)^k/(k!) = sum_(n ge 0)(S(n,k))/(n!)x^n`
Using the exponential generating function for the Stirling numbers, we can also get one for the Bell numbers, `B(n) = sum_(k=0)^nS(n,k)`, which are the number of set partitions of `[n]`.
The exponential generating function would be `sum_(n ge 0)(B(n))/(n!)x^n`
`= sum_(n ge 0)1/(n!)[sum_(k ge 0)S(n,k)]x^n`
`= sum_(k ge 0)sum_(n ge 0)(S(n,k))/(n!)x^n`
`= sum_(k ge 0)(e^x-1)^k/(k!)`
`= e^(e^x-1)`
The advantage of having formulas like these is that it makes taking products much simpler when the formulas are nice and compact, possibly leading to simplifications. It's pretty hard to work with a bunch of summations.
While they are clean formulas, they are often difficult to work with, compared to the formulas obtained from ordinary generating functions, which are usually rational expressions that can be simplified by partial fraction decomposition and expressed as geometric series. Here, there's no easy way to see what the `n^(th)` coefficient of something like `e^(e^x-1)` is.
We compose exponential generating functions when we want to break up `[n]` into blocks, apply a structure on each block, and then apply another structure on a set of those blocks.
Let `alpha` be a structure on a set.
Let `a_n` be the number of ways to do `alpha` on a set of size `n` (assume `a_0=0`).
Define `h_n` to be the number of ways to pick a set partition on `[n]` into `k` blocks for some `k` and put structure `alpha` on each block.
The egf's are `A(x)=sum_(n ge 0)a_n/(n!)x^n` and `H(x) = sum_(n ge 0)h_n/(n!)x^n`.
Theorem: `H(x)=e^(A(x))`
`A(x)^k` is the egf for the number of ways to write `[n] = S_1 uu S_2 uu ... uu S_k` such that the `S_i`'s don't overlap and put structure `alpha` on each `S_i`
Since now the order doesn't matter, we divide by `k!` to get `(A(x)^k)/(k!)`
Considering all `k`, we get `H(x) = sum_(k ge 0) (A(x)^k)/(k!) = e^(A(x))`
Example: A bijection `f:S rarr S` is an involution if `f circ f = id_s`. Applying the function to one element twice results in the original element
Let `h_n` be the number of involutions of a set of size `n`
Find a formula for `H(x) = sum_(n ge 0)h_n/(n!)x^n`
Involutions are built out of two pieces:
So we can think of involutions as set partitions of `[n]` into blocks of size `1` or `2`
Let `alpha` be the structure where we apply the identity function on an element or swap two elements
Then `a_1=a_2=1` and `a_n=0` otherwise
`A(x) = sum_(n ge 0)a_n/(n!)x^n`
`= x + (x^2)/(2!)`
`H(x) = e^(A(x))`
`= e^(x+(x^2)/(2!))`
Example: Let `h_n` be the number of ways to split up `n` people into nonempty groups and have each sit in a circle
Find a formula for `H(x) = sum_(n ge 0)h_n/(n!)x^n`
Let `alpha` be the number of ways to circularly order a set
There are `n!` ways to order people in a circle, but `n` rotations will be the same ordering
So `a_n = (n!)/n = (n-1)!` and `a_0=0`
`A(x) = sum_(n ge 0)a_n/(n!)x^n`
`= sum_(n ge 1) ((n-1)!)/n!x^n`
`= sum_(n ge 1) (x^n)/n`
`= log(1/(1-x))`
`H(x) = e^(A(x))`
`= e^(log(1/(1-x)))`
`= 1/(1-x)`
In fact, we can actually find a formula for the `h_n`
`sum_(n ge 0)h_n/(n!)x^n = 1/(1-x) = sum_(n ge 0)x^n`
`h_n/(n!) = 1`
`h_n = n!`
After breaking up `[n]` into blocks and putting structure `alpha` on each block, we could take a set of those blocks and put another structure `beta` on a set of those blocks.
Let `beta` be a structure on a set. Let `b_n` be the number of ways to do `beta` on a set of size `n`. The generating function is `B(x) = sum_(n ge 0)b_n/(n!)x^n`.
Now let `h_n` be the number of ways to pick a set partition of `[n]`, put `alpha` on each block, and put `beta` on a set of blocks.
Theorem: `H(x) = B(A(x))`
This is the generalized version of the theorem `H(x) = e^(A(x))` where `B(x) = sum_(n ge 0)1/(n!)x^n = e^x` (all the `b_i`'s are `1`)
The Lagrange inversion formula is a technique for extracting coefficients from a formal power series that satisifies a certain identity.
Suppose `R(x) = sum_(n ge 0)r_n/(n!)x^n` satisfies `R(x) = xe^(R(x))`
It's difficult to isolate `R(x)` in this situation
One thing we could do is to solve for the coefficients one by one
`r_0 = 0` because there's no constant term in `xe^(R(x))`
This means that the lowest degree term of `R(x)` is `r_1x^1`, which means that the lowest degree term of `R(x)^n` is `r_1^nx^n`
Rewriting `R(x)=xe^(R(x))` we get
`R(x) = xsum_(n ge 0)1/(n!)R(x)^n`
`= x(1 + R(x) + (R(x)^2)/(2!) + (R(x)^3)/(3!) + ...)`
If we want to find `r_n`, then we only need to consider the first `n` terms, i.e., `x(1+R(x)+...+(R(x)^(n-1))/((n-1)!))`
By definition, `r_1=[x^1]R(x)=[x^1]xe^(R(x))`
From the observation above, we don't need to consider the whole summation; we only need to look at the first term
So `r_1 = [x^1](x(1)) = 1`
`r_2 = [x^2]R(x) = [x^2]e^(R(x))`
`= [x^2](x(1+R(x)))`
`= [x^2](x+xR(x))`
`= [x^2]x + [x^2]xR(x)`
`= 0 + [x^1]R(x)`
`= r_1 = 1`
`r_3 = [x^3]R(x) = [x^3]e^(R(x))`
`= [x^3](x(1+R(x)+(R(x)^2)/(2!)))`
`= [x^3](x+xR(x)+(xR(x)^2)/(2!))`
`= [x^3]x + [x^3]xR(x) + [x^3](xR(x)^2)/(2!)`
`= 0 + [x^2]R(x) + 1/2[x^2]R(x)^2`
`= 0 + r_2 + 1/2(r_0r_2 + r_1r_1 + r_2r_0)`
`= 1 + 1/2 = 3/2`
And we could repeat this process for the rest of the coefficients
The Lagrange inversion formula gives us a way to find the coefficient directly without computing previous coefficients.
Let `G(x)` be a formal power series with a nonzero constant term.
Suppose `A(x)` is a formal power series such that `A(x) = xG(A(x))`.
Theorem: `[x^n]A(x) = 1/n[x^(n-1)](G(x)^n)` for `n gt 0`
Going back to the previous example, we can let `G(x) = e^x` and `A(x) = R(x)`
By the theorem, `r_n = [x^n]R(x)`
`= 1/n[x^(n-1)]e^(nx)`
`= 1/n[x^(n-1)]sum_(k ge 0)1/(k!)(nx)^k`
`= 1/n(1/((n-1)!)n^(n-1))`
`= n^(n-1)/(n!)`
This formula agrees with the previous calculations
`r_1 = 1^0/(1!) = 1`
`r_2 = 2^1/(2!) = 1`
`r_3 = 3^2/(3!) = 9/6 = 3/2`
We can use the Lagrange inversion formula to get the formula for the Catalan numbers fairly easily.
Before, we showed that `C(x) = 1+xC(x)^2`
This isn't in the correct form to use the theorem because of the `1+`. (Also, if we were to use the theorem, then `C(x)` shouldn't have a constant term, but we know that `c_0=1`)
To fix these problems, we could subtract off the constant term
Define `A(x) = C(x)-1`. Now we could use the theorem on `A(x)`
Substituting the identity for `A(x)` we get
`A(x)+1 = 1+x(A(x)+1)^2`
`A(x) = x(A(x)+1)^2`
Let `G(x) = (x+1)^2`, which has a nonzero constant term `1`
So `A(x)=xG(A(x)) implies [x^n]A(x) = 1/n[x^(n-1)](G(x)^n) = 1/n[x^(n-1)](x+1)^(2n)`
`= 1/n[x^(n-1)]sum_(k ge 0)((2n),(k))x^k`
`= 1/n((2n),(n-1))`
`= 1/n((2n)!)/((n-1)!(n+1)!)`
`= ((2n)!)/(n!(n+1)!)`
`= ((2n)!)/(n!n!)1/(n+1)`
`= 1/(n+1)((2n),(n))`
This is the coefficient of `A(x)`, but what we're looking for is the coefficient of `C(x)`
Well the coefficients of `A(x)=C(x)-1` are the same as those for `C(x)` except for the constant term
So `[x^n]A(x) = [x^n]C(x)` for `n gt 0` `implies C_n = 1/(n+1)((2n),(n))`
We can generalize the Catalan numbers in a way that is compatible with the Lagrange inversion formula.
Before, we showed that `C_n` is the number of rooted binary trees with `n+1` leaves
We could generalize this so that `c_n` is the number of rooted `k`-ary trees with `n` internal vertices
Let `C(x) = sum_(n ge 0)c_nx^n` be the ordinary generating function for `c_n`
Removing the root, we get `k` smaller trees
Let `n_i` be the number of internal vertices of the `i^(th)` tree (`n_1+...+n_k=n-1`)
For this choice, there are `c_(n_1), c_(n_2), ..., c_(n_k)` possibilities
So `c_n = sum_(n_1+n_2+...n_k=n-1)c_(n_1)c_(n_2)...c_(n_k)` for `n ge 1`
This is a product of `k` generating functions so we get
`C(x) = 1+xC(x)^k`
To get `c_n`, we could use the Lagrange inversion formula
Let `A(x) = C(x)-1`
Then
`A(x)+1 = 1+x(A(x)+1)^k`
`A(x) = x(A(x)+1)^k`
Let `G(x) = (x+1)^k`
So `A(x)=xG(A(x)) implies [x^n]A(x) = 1/n[x^(n-1)](G(x)^n) = 1/n[x^(n-1)](x+1)^(kn)`
`= 1/n((kn),(n-1))`
The coefficients of `A(x)=C(x)-1` are the same as those for `C(x)` except for the constant term
So `[x^n]A(x) = [x^n]C(x)` for `n gt 0` `implies C_n = 1/(n)((kn),(n-1))`
Inclusion-exclusion is used to count the size of a set that is made up of smaller sets, which may overlap with each other. This means we have to make sure that we don't overcount elements.
Theorem: Let `A_1, A_2, ..., A_n` be finite sets. Then
`|A_1 uu A_2 uu ... uu A_n| = sum_(j=1)^n(-1)^(j-1)sum_(1 le i_1 lt i_2 ... lt i_j le n)|A_(i_1) nn A_(i_2) ... nn A_(i_j)|`
We want every `x in A_1 uu ... uu A_n` to be counted exactly once
Let `S = {s_1, s_2, ..., s_k}` be all the indices such that `x in A_(s_1), ..., A_(s_k)`
`x` is only going to be counted by `(-1)^(j-1)|A_(i_1) nn ... nn A_(i_j)|` when all the `i_1, i_2, ..., i_j` are in `S` (otherwise `x` doesn't belong in the intersection)
So we have to look at all the possible ways of choosing indices in `S`
The number of times `x` is counted is
`sum_(T sube S, T != O/) (-1)^(|T|-1) = sum_(i=1)^(|S|)((|S|),(i))(-1)^(i-1)`
We could simplify that by using the binomial theorem
When `x=-1,y=1` we get
`0 = (1-1)^n = sum_(i=0)^n((n),(i))(-1)^i`
`= 1+sum_(i=1)^n((n),(i))(-1)^i`
So we have `0 = 1+sum_(i=1)^n((n),(i))(-1)^i`
`-sum_(i=1)^n((n),(i))(-1)^i = 1`
`sum_(i=1)^n((n),(i))(-1)^(i-1) = 1`
which looks like the summation above
So the number of times `x` is counted is
`sum_(i=1)^(|S|)((|S|),(i))(-1)^(i-1)=1`
`j` represents how many sets we consider at a time
the inner sum looks at the number of ways to intersect `j` sets
Example: `n=2`
Starting with `j=1`, we take all possible subsets of size `1`:
`|A_1 uu A_2| = color(red)(|A_1|+|A_2|)`
Then when `j=2`, we take all possible subsets of size `2`:
`|A_1 uu A_2| = |A_1|+|A_2|color(red)(-|A_1 nn A_2|)`
Example: `n=4`
All possible subsets of size `1`:
`|A_1 uu A_2 uu A_3 uu A_4| = color(red)(|A_1|+|A_2|+|A_3|+|A_4|)`
All possible subsets of size `2`:
`|A_1 uu A_2 uu A_3 uu A_4| = |A_1|+|A_2|+|A_3|+|A_4|`
`color(red)(-|A_1 nn A_2| - |A_1 nn A_3| - |A_1 nn A_4| - |A_2 nn A_3| - |A_2 nn A_4| - |A_3 nn A_4|)`
All possible subsets of size `3`:
`|A_1 uu A_2 uu A_3 uu A_4| = |A_1|+|A_2|+|A_3|+|A_4|`
`-|A_1 nn A_2| - |A_1 nn A_3| - |A_1 nn A_4| - |A_2 nn A_3| - |A_2 nn A_4| - |A_3 nn A_4|`
`color(red)(+|A_1 nn A_2 nn A_3| + |A_1 nn A_2 nn A_4| + |A_1 nn A_3 nn A_4| + |A_2 nn A_3 nn A_4|)`
All possible subsets of size `4`:
`|A_1 uu A_2 uu A_3 uu A_4| = |A_1|+|A_2|+|A_3|+|A_4|`
`-|A_1 nn A_2| - |A_1 nn A_3| - |A_1 nn A_4| - |A_2 nn A_3| - |A_2 nn A_4| - |A_3 nn A_4|`
`+|A_1 nn A_2 nn A_3| + |A_1 nn A_2 nn A_4| + |A_1 nn A_3 nn A_4| + |A_2 nn A_3 nn A_4|`
`color(red)(-|A_1 nn A_2 nn A_3 nn A_4|)`
When proving things using inclusion-exclusion, we want to express our set as one that satisfies one of `n` conditions. Then each `A_i` is the set that only satisfies condition `i`. The union of all the `A_i`'s will be our original set.
A bijection `f:S rarr S` is a derangement if `f(s)!=s` for all `s in S`
Theorem: The number of derangements of a set of size `n` is `sum_(i=0)^n(-1)^i(n!)/(i!)`
It's easier to count the number of non-derangements and subtract from the total number of permutations
`f` is not a derangement if `f(1)=1` or `f(2)=2` or `...\ f(n) = n`
Let `A_i = {f:[n] rarr [n]|f(i)=i}`. So all the non-derangements are included in `A_1 uu A_2 uu ... uu A_n`
`A_1` is the set of all bijections such that `f(1)=1`. For `2,...,n` there are `(n-1)!` ways to assign values, so `|A_1|=(n-1)!`
By similar reasoning, `|A_2| = ... = |A_n| = (n-1)!`
`A_1 nn A_2` is the set of all bijections such that `f(1)=1` and `f(2)=2`. For `3,...,n` there are `(n-2)!` ways to assign values, so `|A_1 nn A_2| = (n-2)!`
In general, `|A_(i_1) nn ... nn A_(i_j)| = (n-j)!`
Since the union of all the `A_i`'s gives us the number of non-derangements, we can use inclusion-exclusion
`|A_1 uu ... uu A_n| = sum_(j=1)^n(-1)^(j-1)sum_(1 le i_1 lt ... lt i_j le n)|A_(i_1) nn ... nn A_(i_j)|`
`= sum_(j=1)^n(-1)^(j-1)sum_(1 le i_1 lt ... lt i_j le n)(n-j)!`
`= sum_(j=1)^n(-1)^(j-1)((n),(j))(n-j)!`
`= sum_(j=1)^n(-1)^(j-1)(n!)/(j!)`
The number of derangements is the number of permutations minus the number of non-derangements, which is
`n!-sum_(j=1)^n(-1)^(j-1)(n!)/(j!)`
`= n!+sum_(j=1)^n(-1)^j(n!)/(j!)`
`= sum_(j=0)^n(-1)^j(n!)/(j!)`
the last part can be seen as rewriting `n!` as `(n!)/(0!)`
Big idea: To be a non-derangement, it needs to satisfy (at least) one of `n` conditions. The set of non-derangements is the union of `n` simpler sets.
Formulas obtained from inclusion-exclusion will have alternating signs, which makes it hard to tell how big that quantity is. For example, is `sum_(i=0)^n(-1)^i(n!)/(i!)` a big or small number? It turns out that this specific formula (accidentally?) has another nice interpretation that can be obtained using calculus.
Example: What percentage of permutations are derangements?
The answer is the number of derangements divided by the number of permutations, which is
`1/(n!)sum_(j=0)^n(-1)^j(n!)/(j!)`
`= sum_(j=0)^n(-1)^j/(j!)`
From calculus,
`e^x = sum_(i ge 0)x^i/(i!)`
`e^x` converges everywhere, so if we plug in a number for `x`, that series will converge
Also, the larger `n` gets, the closer we get to the value. So even though it's an infinite sum, large enough `n` will provide a good enough approximation
Plugging in `x=-1`, we get
`e^(-1) = sum_(i ge 0)(-1)^i/(i!) ~~ sum_(i=0)^n(-1)^i/(i!)`
So the number of derangements is
`= sum_(j=0)^n(-1)^j/(j!) ~~ 1/e ~~ 0.367...`
In a room with a lot of people, if we throw everyone's hat into a pile and randomly give everyone a hat, there's about a `37%` chance that no one will get their own hat back
We can also use inclusion-exclusion to get a formula for the Stirling numbers. `S(n,k)` is the number of set partitions of `[n]` into `k` blocks. `k!S(n,k)` is the number of ordered set partitions of `[n]` into `k` blocks. It can also be thought of as the number of surjective functions from `[n]` to `[k]`.
Theorem: `S(n,k) = 1/(k!)sum_(i=0)^k(-1)^i((k),(i))(k-i)^n` for `n ge k gt 0`
Count the number of non-surjective functions from `[n]` to `[k]` and subtract from the total number of functions from `[n]` to `[k]`
Being non-surjective means `1` is not in the image or `2` is not in the image or `...\ k` is not in the image
Define `A_i = {f:[n] rarr [k]|i` is not in the image of `f}` for `1 le i le k`
Then the set of non-surjective functions is the union of the `A_i`'s
`A_1` is all the functions where `1` is not in the image, which is the same as `{`functions `[n] rarr {2,3,...,k}}`
There are `(k-1)^n` such functions, so `|A_1| = (k-1)^n`
By similar reasoning, `|A_i| = (k-1)^n` for all `i`
`A_1 nn A_2 = {`functions `[n] rarr {3,4,...,k}}` so `|A_1 nn A_2| = (k-2)^n`
In general, `|A_(i_1) nn ... nn A_(i_j)| = (k-j)^n`
The number of non-surjective functions is
`|A_1 uu ... uu A_k| = sum_(j=1)^k(-1)^(j-1)sum_(1 le i_1 lt ... lt i_j le k)|A_(i_1) nn ... nn A_(i_j)|`
`= sum_(j=1)^n(-1)^(j-1)sum_(1 le i_1 lt ... lt i_j le k)(k-j)^n`
`= sum_(j=1)^n(-1)^(j-1)((k),(j))(k-j)^n`
The number of surjective functions is the total number of functions minus the number of non-surjective functions, so we have
`k!S(n,k) = k^n - sum_(j=1)^k(-1)^(j-1)((k),(j))(k-j)^n`
`k!S(n,k) = k^n + sum_(j=1)^k(-1)^j((k),(j))(k-j)^n`
`k!S(n,k) = sum_(j=0)^k(-1)^j((k),(j))(k-j)^n`
To get the Stirling numbers, divide by `k!`:
`S(n,k) = 1/(k!)sum_(j=0)^k(-1)^j((k),(j))(k-j)^n`
Möbius inversion deals with a different kind of overcounting. It usually shows up in number theory, but we can use it to count necklaces.
Let `A` be an alphabet of size `k`. We want to count the number of words of length `n` up to cyclic symmetry. The idea is that if we arrange the letters in a circle, each rotation would be considered the same word.
For example, `a_1a_2a_3a_4 -= a_4a_1a_2a_3 -= a_3a_4a_1a_2 -= a_2a_3a_4a_1`
Because of the cyclic symmetry, we have to divide out the commonalities to get the number of unique arrangements. It seems like the number of symmetries is equal to the number of times we can shift it to get the same word back.
One idea is to divide the number of words of length `n` by the length of the word.
`= k^n/n`
The problem with this idea is that not every word is overcounted equally.
For example, `a_1a_1a_1a_1` is not overcounted four times; it is only overcounted once
The number of symmetries is actually equal to the number of times we can shift it. It's just not always equal to the length of the word.
Given a word, its period is the least number of times we need to rotate it to get the original word back
Fact: the period always divides the length of the word
Let `omega(d)` be the number of words of period `d`
To count the number of necklaces, we can count the number of words with period `1, 2, ..., n`, dividing out the commonalities in each case.
`#\ text(necklaces) = sum_(d|n)(omega(d))/d`
The number of necklaces of length `4`
`= (omega(1))/1 + (omega(2))/2 + (omega(4))/4`
`= k + (k(k-1))/2 + (k^4-k-(k(k-1)))/4`
It's tempting to think that the number of words with period `4` is `n(n-1)(n-2)(n-3)`
But there are words with period `4` that don't have all distinct letters, such as `1312`
To count the number of words with period `4`, we count the total number of words of length `4` and subtract off words with period `1` and period `2`
If a word of length `4` doesn't have period `1` or period `2`, then it must have period `4`
This idea actually leads to another identity
The number of words of length `n` is the number of words with period `1, 2, ..., n`
`k^n = sum_(d|n)omega(d)`
This is valid for any `n`, so this gives us a system of equations we can use to solve for each `omega(d)`
For `n=4`:
`k^4 = omega(4)+omega(2)+omega(1)`
`k^2 = omega(2)+omega(1)`
`k^1 = omega(1)`
Which gives us
`omega(1) = k`
`omega(2) = k^2-omega(1) = k^2-k`
`omega(4) = k^4-omega(2)-omega(1) = k^4-k^2+k-k = k^4-k^2`
For `n=6`:
`k^6 = omega(6)+omega(3)+omega(2)+omega(1)`
`k^3 = omega(3)+omega(1)`
`k^2 = omega(2)+omega(1)`
`k^1 = omega(1)`
Which gives us
`omega(1) = k`
`omega(2) = k^2-omega(1) = k^2-k`
`omega(3) = k^3-omega(1) = k^3-k`
`omega(6) = k^6-omega(3)-omega(2)-omega(1) = k^6-k^3+k-k^2+k-k = k^6-k^3-k^2+k`
We could use this system of equations to manually solve for `omega(d)` and calculate the number of necklaces that way. But it would be nicer to find a pattern for `omega(d)` and solve for it directly.
For `n gt 1`, write `n` as a product of primes
The Möbius function is defined by
`mu(n) = {(0\ text(if n is divisible by a square of some prime)), ((-1)^k\ text(if n is a product of k different primes)):}`
and `mu(1)=1`
`mu(12) = mu(2^2*3) = 0`
`mu(30) = mu(2*3*5) = (-1)^3 = -1`
`mu(8) = mu(2^3) = 0`
Lemma: `sum_(d|n)mu(d) = 0` for `n gt 1`
Consider the prime factorization of `n = p_1^(a_1)p_2^(a_2)...p_r^(a_r)` where each `p_i` is distinct and all `a_i gt 0`
To get divisors of `n`, we just make the exponents smaller
So all divisors `d` of `n` are of the form `d = p_1^(b_1)p_2^(b_2)...p_r^(b_r)` where `0 le b_i le a_i`
We can rewrite the sum as
`sum_(d|n)mu(d) = sum_(0 le b_i le a_i)mu(p_1^(b_1)p_2^(b_2)...p_r^(b_r))`
By the Möbius function, if `n` is divisible by a prime more than once, then the result is `0`. So we only need to consider `b_i`'s `lt 2`:
`= sum_(0 le b_i le 1)mu(p_1^(b_1)p_2^(b_2)...p_r^(b_r))`
Since each `b_i` is either `0` or `1`, we either include each `p_i` or we don't:
`= sum_(S sube [r])mu(prod_(i in S)p_i)`
We have a product of distinct primes so the result will be `(-1)` to some power by the Möbius function:
`= sum_(S sube [r])(-1)^(|S|)`
`= sum_(j=0)^r (-1)^j((r),(j)) = 0`
by the binomial theorem with `x=-1,y=1`
Theorem: `omega(d) = sum_(e|d)mu(d/e)k^e` for any `d`
From the identity before, we can rewrite `k^e` as a sum of `omega`'s
`sum_(e|d)mu(d/e)k^e = sum_(e|d)mu(d/e)sum_(f|e)omega(f)`
We can rearrange the sum to get
`= sum_(f|d)(omega(f)sum_(e|d, e\ text(divisible by )f)mu(d/e))`
`= sum_(f|d)(omega(f)sum_(g|d/f)mu(g))color(red)(text(*))`
By the lemma, `sum_(g|d/f)mu(g) = 0` if `d/f gt 1 implies d gt f`
So we don't need to consider all the terms where `d gt f`. The only term left is when `f=d`:
`= omega(d)sum_(g|d/d)mu(g)`
`= omega(d)sum_(g|1)mu(g)`
`= omega(d)sum_(1)1`
`= omega(d)`
`color(red)(text(*))`We can define a function `varphi:{e|e\ ` divides `d` and `e` is divisible by `f} rarr {g|g` divides `d/f}` by `varphi(e)=d/e`
`varphi` is a bijection, so we can rewrite the sum
We could verify that this theorem is consistent with the previous examples for `d=4` and `d=6`
`omega(4) = mu(4/1)k^1 + mu(4/2)k^2 + mu(4/4)k^4`
`= mu(2^2)k^1 + mu(2)k^2 + mu(1)k^4`
`= -k^2 + k^4`
`omega(6) = mu(6/1)k^1 + mu(6/2)k^2 + mu(6/3)k^3 + mu(6/6)k^6`
`= mu(2*3)k^1 + mu(3)k^2 + mu(2)k^3 + mu(1)k^6`
`= k - k^2 - k^3 + k^6`
Counting necklaces is a specific case of Möbius inversion. Generally, we use Möbius inversion when we have a function that is a sum of another function, and we want to write it the other way around.
Theorem: Let `f,g` be functions defined on positive integers. Assume that `f(n) = sum_(d|n)g(d)` for all `n ge 1`
Then `g(d) = sum_(e|d)mu(d/e)f(e)` for all `d ge 1`
In the necklace problem, `f(n) = k^n` and `g(d) = omega(d)`
3.1: How many functions are there from `[n]` to `[n]` that are not one-to-one?
Count the number of functions that are one-to-one and subtract from the total number of functions
Total number of functions: there are `n` choices in the codomain for each element in the domain `implies n^n`
One-to-one: assign each element in the domain one element in the codomain and permute `implies n!`
`color(red)(n^n - n!)`
3.2: Prove that the number of subsets of `[n]` that have an odd number of elements is `2^(n-1)`
For each of the first `n-1` elements, there are `2` choices: in the subset or not in the subset `implies 2^(n-1)`
For the `n^(th)` element, there is only `1` choice:
3.3: A company has `20` employees, `12` males and `8` females. How many ways are there to form a committee of `5` employees that contains at least one male and one female?
Count the number of committees that have all males and all females and subtract both from the total number of ways to form a committee
Total number of ways to form a committee: `((20),(5))`
All male: `((12),(5))`
All female: `((8),(5))`
`color(red)(((20),(5)) - ((12),(5)) - ((8),(5)))`
3.6: How many five-digit positive integers are there with middle digit `6` that are divisible by three?
This problem is the same as counting the number of four-digit positive integers divisible by three since `6` is divisible by three
There are `9999-1000+1 = 9000` four-digit positive integers
Every third number is divisible by three `implies 1/3` of the `9000` four-digit positive integers are divisible by three
`color(red)(3000)`
3.7: How many five-digit positive integers are there that contain the digit `9` and are divisible by three?
There are `99999-10000+1 = 90000` five-digit positive integers
Every third number is divisible by three `implies 1/3*90000 = 30000` five-digit positive integers are divisible by three
Now count how many of those don't contain a `9` and subtract from the total number of five-digit positive integers divisible by three
There are `8` choices for the first digit
There are `9` choices for the second digit
There are `9` choices for the third digit
There are `9` choices for the fourth digit
The fifth digit depends on what the first `4` digits sum up to
There are `3` choices for the fifth digit
`color(red)(30000-(8*9*9*9*3))`
3.8: How many ways are there to list the digits `{1,2,2,3,4,5,6}` so that identical digits are not in consecutive positions?
Count the number of ways to list the digits where they are in consecutive positions and subtract from the total number of ways to list the digits
Total number of ways to list digits: `(7!)/(2!)`
Consecutive positions: combine the `2`'s into one `2`, then there are `6!` ways to list the digits
`color(red)((7!)/(2!) - 6!)`
Alternatively, there are `6` positions where the `2`'s could go, then there are `5!` ways to rearrange the remaining digits `implies 6*5! = 6!`
3.9: How many ways are there to list the digits `{1,1,2,2,3,4,5}` so that the two `1`'s are in consecutive positions?
Combine the two `1`'s together into one `1`, then there are `(6!)/(2!)` ways to list the digits
`color(red)((6!)/(2!))`
Alternatively, there are `6` positions where the `1`'s could go, then there are `(5!)/(2!)` ways to rearrange the remaining digits `implies 6*(5!)/(2!) = (6!)/(2!)`
3.10: A cashier wants to work five days a week, but he wants to have at least one of Saturday and Sunday off. In how many ways can he choose the days he will work?
Count the number of ways where he works on Saturday and Sunday and subtract from the total number of ways to choose the five days
Total number of ways to choose five days: `((7),(5))`
Works on Saturday and Sunday: `((5),(3))`
`color(red)(((7),(5))-((5),(3)))`
3.11: A car dealership employs five salespeople. Yesterday the dealership sold seven cars. In how many different ways could this happen?
This is a `7`-element multiset of `[5]`
Alternatively, it is also a weak composition of `7` into `5` parts
`color(red)(((11),(7)))`
3.12: A traveling agent has to visit four cities, each of them five times. In how many different ways can he do this if he is not allowed to start and finish in the same city?
Count the number of ways to do this where he starts and finishes in the same city and subtract from the total number of ways to visit four cities five times each
Consider a random permutation of cities
Total number of ways:
Start and finish in the same city:
`color(red)((20!)/(5!5!5!5!) - 4*(18!)/(5!5!5!3!))`
3.14: A restaurant offers five soups, ten main courses, and six desserts. Joe decided to order at most one soup, at most one main course, and at most one dessert. In how many ways can he do this?
For each meal, not getting it is an option
There are `6` choices for soup
There are `11` choices for soup
There are `7` choices for soup
`color(red)(6*11*7)`
3.18: How many `6`-digit positive integers are there in which the sum of the digits is at most `51`?
Count the number of `6`-digit positive integers in which the sum of the digits is more than `51` and subtract from the total number of `6`-digit positive integers
Total number of `6`-digit positive integers: `999999-100000+1 = 900000`
There are `4` situations where the sum of the digits is more than `51`:
`color(red)(900000-(1+6+6+((6),(2))))`
3.19: How many ways are there to select an `11`-member soccer team and a `5`-member basketball team from a class of `30` students if
(a) nobody can be on `2` teams
(b) any number of students can be on both teams
(c) at most one student can be on both teams?
(a) First, pick `11` students for the soccer team: `((30),(11))`
From the remaining `19` students, pick `5` of them to be on the basketball team: `((19),(5))`
`color(red)(((30),(11))*((19),(5)))`
(b) First, pick `11` students for the soccer team: `((30),(11))`
Since we can have students on both teams, we can pick `5` students for the basketball team from the same set of `30` students: `((30),(5))`
`color(red)(((30),(11))*((30),(5)))`
(c) It is valid to have a situation where no student is on both teams. This is part (a): `((30),(11))*((19),(5))`
The (only) other valid situation is to have `1` student on both teams
First, pick `10` students for the soccer team: `((30),(10))`
(the `11^(th)` spot is reserved for the student who is on both teams)
From the remaining `20` students, pick `4` of them to be on the basketball team: `((20),(4))`
(the `4^(th)` spot is reserved for the student who is on both teams)
From the remaining `16` students, pick `1` of them to be on both teams: `16`
`color(red)(((30),(11))*((19),(5)) + ((30),(10))*((20),(4))*16)`
Alternatively, first pick the student who will be on both teams: `30`
From the remaining `29` students, pick `10` of them to be on the soccer team: `((29),(10))`
From the remaining `19` students, pick `4` of them to be on the basketball team: `((19),(4))`
`color(red)(((30),(11))*((19),(5)) + 30*((29),(10))*((19),(4)))`
3.20: Suppose all cars have license plates consisting of six numerical digits only. How many license plates have only one digit that occurs more than once and that digit occurs exactly three times? For example, `404824`.
Pick the digit that will occur three times: `10` choices
From the six positions, pick three of them to be the places where the repeated digit will be: `((6),(3))`
The rest of the digits have to be distinct since there is only one digit that occurs more than once
The fourth digit, regardless of position, has `9` choices
The fifth digit, regardless of position, has `8` choices
The sixth digit, regardless of position, has `7` choices
`color(red)(10*((6),(3))*9*8*7)`
Alternatively,
There are `10` choices for the digit that appears three times
There are `9` choices for the fourth digit
There are `8` choices for the fifth digit
There are `7` choices for the sixth digit
There are `(6!)/(3!)` ways to arrange the six digits
`color(red)(10*9*8*7*(6!)/(3!))`
3.23: In how many different ways can we place `8` identical rooks on a chess board so that no two of them attack each other?
Place a rook on any row/column: `8` choices
There are `7` remaining rows/columns for the next rook
There are `6` remaining rows/columns for the next rook
`vdots`
There is `1` remaining row/column for the last rook
`color(red)(8!)`
Alternatively, place the `8` rooks in such a way so that none of them are attacking each other (e.g. place them all along a diagonal)
There are `8!` ways to rearrange them and still have them not attacking each other
(swapping two rows/columns will ensure that they are still not attacking each other)
3.25: How many three-digit positive integers contain two (but not three) different digits?
Count the number of three-digit positive integers that contain only one different digit and the number of three-digit positive integers that contain three different digits and subtract both from the total number of three-digit positive integers
Total number of three-digit positive integers: `999-100+1 = 900`
three-digit positive integers with only one different digit:
three-digit positive integers with three different digits:
`color(red)(900-9-9*9*8)`
3.27: How many subsets does `[n]` have that contain exactly one of the elements `1` and `2`?
Consider the subsets of `{3,4,...,n}`
There are `n-2` elements `implies 2^(n-2)` subsets
For each subset, there are `2` choices: put a `1` or put a `2`
`2*2^(n-2) = color(red)(2^(n-1))`
3.28: How many subsets does `[n]` have that contain at least one of the elements `1` and `2`?
Consider the subsets of `{3,4,...,n}`
There are `n-2` elements `implies 2^(n-2)` subsets
For each subset, there are `3` choices: put a `1`, put a `2`, or put both
`color(red)(3*2^(n-2))`
3.29: How many three-digit positive integers start and end with an even digit?
There are `4` choices for the first digit (can't be `0`)
There are `10` choices for the second digit
There are `5` choices for the third digit
`color(red)(4*10*5)`
3.30: How many four-digit positive integers are there in which all digits are different?
There are `9` choices for the first digit (can't be `0`)
There are `9` choices for the second digit
There are `8` choices for the third digit
There are `7` choices for the fourth digit
`color(red)(9*9*8*7)`
3.31: How many four-digit positive integers are there that contain the digit `1`?
Count the number of four-digit positive integers that don't contain the digit `1` and subtract from the total number of four-digit positive integers
Total number of four-digit positive integers: `9999-1000+1 = 9000`
Don't contain `1`:
`color(red)(9000-8*9*9*9)`
3.32: How many three-digit numbers are there in which the sum of the digits is even?
There are four situations where the sum of the digits is even:
For the case where all digits are even:
For even odd odd:
For odd even odd:
For odd odd even:
`color(red)(100+100+125+125 = 450)`
3.33: In how many ways can the elements of `[n]` be permuted if
(a) `1` is to precede `2` and `3` is to precede `4`
(b) `1` is to precede both `2` and `3`?
(a) Consider the set `[4]`
There are six situations where this happens:
Now consider adding `5`
There are `5` choices where it could be placed for each of the six situations
Now consider adding `6`
There are `6` choices where it could be placed for each of the six situations
`vdots`
Now consider adding `n`
There are `n` choices where it could be placed for each of the six situations
`color(red)(6*(n)_(n-4) = 6*n*(n-1)*...*6*5)`
(b) Consider the set `[3]`
There are two situations where this happens:
Now consider adding `4`
There are `4` choices where it could be placed for each of the two situations
`vdots`
Now consider adding `n`
There are `n` choices where it could be placed for each of the two situations
`color(red)(2*(n)_(n-2) = 2*n*(n-1)*...*5*4)`
3.37: A student needs to work five days in January. He does not want to work on more than one Sunday. In how many ways can he select his five working days? (Assume that January has five Sundays.)
There are two situations:
For the case where none of the days is Sunday, there are `26` days to choose from: `((26),(5))`
For the case where one of the days is Sunday:
`color(red)(((26),(5))+5*((26),(4)))`
3.38: A host invites `n` couples to a party. She wants to ask a subset of the `2n` guests to give a speech, but she does not want to ask both members of any couple to give speeches. In how many ways can she proceed?
For each of the `n` couples there are `3` options:
`color(red)(3^n)`
3.40: How many different ways can we select ordered pairs `(A,B)` of subsets of `[n]` so that `A nn B != O/`?
Count the number of ways to pick ordered pairs `(A,B)` such that `A nn B = O/` and subtract from the total number of ways to select ordered pairs `(A,B)`
Total number of ways to pick ordered pairs `(A,B)`:
Any element in `[n]` can be:
`4^n` ways
For the case where `A nn B = O/`:
Any element can be:
`3^n` ways
`color(red)(4^n-3^n)`
3.41: How many different ways are there to select three subsets `A`,`B`, and `C` of `[n]` so that `A sube C`, `B sube C` and `A nn B != O/`?
Count the number of way to pick subsets so that `A nn B = O/` and subtract from the total number of ways to pick subsets
Total number of ways to pick subsets:
Any element in `[n]` can be:
`5^n` ways
For the case where `A nn B = O/`:
Any element in `[n]` can be:
`4^n` ways
`color(red)(5^n-4^n)`
3.42: A two-day math conference has `n` participants. Some of the participants give a talk on Saturday, some others give a talk on Sunday. Nobody gives more than one talk, and there may be some people who do not give a talk at all. At the end of the conference, a few talks are selected to be included in a book. In how many different ways is this all possible if there is at least one talk selected for inclusion in the book?
Count the number of ways for people to give talks without any of them being included in the book and subtract from the total number of ways for people to give talks
Total number of ways for people to give talks:
There are five situations for each person:
`5^n` ways
For the case where no talk is selected to be in the book, there are three situations for each person:
`3^n` ways
`color(red)(5^n-3^n)`
3.43: A group organizing a faculty-student tennis match must match four faculty volunteers to four of the `13` students who volunteered to be in the match. In how many ways can they do this?
The first faculty volunteer has `13` students from which to choose
The second faculty volunteer has `12` students from which to choose
The third faculty volunteer has `11` students from which to choose
The fourth faculty volunteer has `10` students from which to choose
`color(red)(13*12*11*10)`
3.45: A student will study `26` hours in preparation for an exam. She will do this in the course of six consecutive days. On each of these days, she will study either four hours, five hours, or six hours. In how many different ways is this possible?
Let `a` be the number of days she studies for four hours
Let `b` be the number of days she studies for five hours
Let `c` be the number of days she studies for six hours
Considering the conditions, we get the system of equations
`a+b+c = 6`
`4a+5b+6c = 26`
`implies b + 2c = 2`
So `b = 2, c = 0, a = 4` (five hours for `2` days and four hours for `4` days)
or
`b = 0, c = 1, a = 5` (six hours for `1` day and four hours for `5` days)
For the case where she studies for four hours for `4` days and five hours for `2` days:
For the case where she studies for four hours for `5` days and six hours for `1` day:
`color(red)(15+6 = 21)`
3.46: Andy and Brenda throw four dice at the same time. If at least one of the four dice shows a six, then Andy wins, if not then Brenda. Who has a greater chance of winning?
Calculate Brenda's chance of winning by counting the number of possibilities where none of the dice show a six
Total number of possibilities:
None of them show a six:
Brenda has a `(5^4)/(6^4) = 625/1296` chance of winning
Andy has a `671/1296` chance of winning
`color(red)(text(Andy))`
3.49: A class is attended by `n` sophomores, `n` juniors, and `n` seniors. In how many ways can these students form `n` groups of three people each if each group is to contain a sophomore, a junior, and a senior?
For the first sophomore, there are `n` choices of juniors and `n` choices of seniors
For the second sophomore, there are `n-1` choices of juniors and `n-1` choices of seniors
For the third sophomore, there are `n-2` choices of juniors and `n-2` choices of seniors
`vdots`
For the last sophomore, there is `1` choice for the junior and `1` choice for the senior
`color(red)(n!*n!)`
3.50: The NFL consists of `32` teams. These teams are first divided into two conferences, the American Conference and the National Conference, each of which consists of sixteen teams. Then each conference is divided into four divisions of four teams each. Each division has a distinct name. In how many ways can this be done?
There are a total of `8` divisions
There are `((32),(4))` choices for the first division
There are `((28),(4))` choices for the second division
There are `((24),(4))` choices for the third division
`vdots`
There are `((8),(4))` choices for the seventh division
There are `((4),(4))` choices for the eighth division
`color(red)(((32),(4))*((28),(4))*((24),(4))*...*((8),(4))*((4),(4)))`
5.19: What is the number of partitions of `[8]` into two blocks in which the two blocks do not have the same size?
There are `3` situations where the two blocks do not have the same size:
`color(red)(((8),(1))+((8),(2))+((8),(3)))`
5.20: What is the number of compositions of `5` with a unique largest part?
There are five types of compositions of `5` with a unique largest part:
`color(red)(1+2+2+3+4 = 12)`
5.22: A student has to take twelve hours of classes a week. She must take at least three hours on Monday, at least two on Thursday, and at least one on Friday. In how many ways can she do this?
Let `a,b,c,d,e` be the number of hours she takes on Monday, Tuesday, Wednesday, Thursday, and Friday respectively
`a+3 + b + c + d+2 + e+1 = 12`
`a+b+c+d+e = 6`
This is a weak composition of `6` into `5` parts
`color(red)(((10),(6)))`
5.23: Find the number of compositions of ten into even parts
`2x_1 + 2x_2 + ... + 2x_n = 10`
`2(x_1 + x_2 + ... + x_n) = 10`
`x_1 + x_2 + ... + x_n = 5`
This is the same problem as the number of compositions of `5` into integer parts
`color(red)(2^(5-1) = 2^4 = 16)`
5.24: Find the number of weak compositions of `25` into five odd parts
`x_1 + x_2 + x_3 + x_4 + x_5 = 25` where `x_1, ..., x_5` are odd integers
Let `x_i = 2y_i+1`
`2y_1+1 + 2y_2+1 + 2y_3+1 + 2y_4+1 + 2y_5+1 = 25`
`2(y_1 + y_2 + y_3 + y_4 + y_5) = 20`
`y_1 + y_2 + y_3 + y_4 + y_5 = 10`
This is a weak composition of `10` into `5` parts
`color(red)(((14),(10)))`
5.25: A student has to take eight hours of classes a week. He wants to have fewer hours on Friday than on Thursday. In how many ways can he do this?
Let `a,b,c,d,e` be the number of hours he takes on Monday, Tuesday, Wednesday, Thursday, and Friday respectively
`a+b+c+d+e = 8` where `d gt e`
He could take `0, 1, 2, 3` hours on Friday
Since he wants fewer hours on Friday than on Thursday, we add `e+1` hours to `d` to maintain the rule `d gt e` and to turn the problem into a weak composition problem
`e=0: a+b+c+(d+1)+0=8 implies a+b+c+d=7 implies ((10),(7))`
`e=1: a+b+c+(d+2)+1=8 implies a+b+c+d=5 implies ((8),(5))`
`e=2: a+b+c+(d+3)+2=8 implies a+b+c+d=3 implies ((6),(3))`
`e=3: a+b+c+(d+4)+3=8 implies a+b+c+d=1 implies ((4),(1))`
`color(red)(((10),(7))+((8),(5))+((6),(3))+((4),(1)))`
5.27: Find a closed formula for `S(n,n-2)` for all `n ge 3`
There are only two ways to have `n-2` blocks:
`color(red)(((n),(3))+((n),(4))*((4),(2))*1/2)`
Alternatively, for the two blocks of size `2`, we could choose two numbers to be in one block, then choose another two to be in the other block: `((n),(2))*((n-2),(2))*1/2`
5.28: Find a closed formula for `S(n,n-3)` for all `n ge 4`
There are only `3` ways to have `n-3` blocks:
`color(red)(((n),(4))+((n),(5))*((5),(3))+((n),(2))*((n-2),(2))*((n-4),(2))*1/(3!))`
Alternatively, for the one block of size `3`, we could do `((n),(3))*((n-3),(2))`
5.32: Let `F(n)` be the number of all partitions of `[n]` with no singleton blocks. Prove that `B(n) = F(n) + F(n+1)`
`B(n)-F(n)` is the number of partitions of `[n]` where each partition has at least one singleton
Goal: Prove `B(n)-F(n) = F(n+1)`
Claim: There is a bijection between `A = {`partitions of `[n]` such that there is at least one singleton`}` and `B = {`partitions of `[n+1]` such that every block has size `gt 1}`
Let `f:A rarr B` be defined as follows:
For a partition in `A`, add the singleton `{n+1}` and merge together all the singleton blocks into one block
This produces an element in `B` because there are no singleton blocks, i.e., every block has size `gt 1`
Let `g:B rarr A` be defined as follows:
For a partition in `B`, break up the block containing `n+1` into singletons and remove the singleton `{n+1}`
This produces an element in `A` because there are now singleton blocks, i.e., there is at least one block with size `1`
So `g` is the inverse of `f`
`implies f` is a bijection
`implies |A| = |B|`
`implies B(n)-F(n) = F(n+1)`
`implies B(n) = F(n) + F(n+1)`
4.3: Prove that `2^(n-2)*n*(n-1) = sum_(k=2)^n k(k-1)((n),(k))` for all integers `n ge 2`
Start with the binomial theorem
`(x+y)^n = sum_(k=2)^n((n),(k))x^ky^(n-k)`
Take the derivative (with respect to `x`) of both sides twice
`n*(x+y)^(n-1) = sum_(k=2)^n((n),(k))kx^(k-1)y^(n-k)`
`n*(n-1)*(x+y)^(n-2) = sum_(k=2)^n((n),(k))k(k-1)x^(k-2)y^(n-k)`
Plug in `x=y=1`
`n*(n-1)*2^(n-2) = sum_(k=2)^n((n),(k))k(k-1)`
4.4: Let `k,m,n` be nonnegative integers integers such that `k+m le n`. Prove that `((n),(m))*((n-m),(k)) = ((n),(k))((n-k),(m))`
The left-hand side is counting the number of ways to
The right-hand side is counting the number of ways to
Both are counting the number of ways to form an `m`-member soccer team and a `k`-member basketball team
4.8: Prove that for all positive integers `n`, the inequality `((2n),(n)) lt 4^n` holds
`((2n),(n))` is the number of `n`-element subsets of `[2n]`
`4^n = 2^(2n)` is the number of all subsets of `[2n]`
4.9: How many subsets of `[n]` are larger than their complements?
Pair each subset with its complement
If `n` is odd:
If `n` is even, then let `n = 2k`
`sum_(i=0)^(k-1)((n),(i))` counts the number of subsets that are larger than their complements
To get that summation, we could split the subsets of `[n]` into three groups:
So we have
`2^n = ((n),(n/2))+2sum_(i=0)^(k-1)((n),(i))`
`2sum_(i=0)^(k-1)((n),(i)) = 2^n-((n),(n/2))`
`sum_(i=0)^(k-1)((n),(i)) = (2^n-((n),(n/2)))/2`
`sum_(i=0)^(k-1)((n),(i)) = color(red)(2^(n-1)-1/2((n),(n/2)))`
4.17: Prove that `sum_(a_1+a_2+a_3=n)((n),((a_1,a_2,a_3)))=3^n`
Start with the multinomial theorem
`sum_(a_1+a_2+a_3=n)((n),((a_1,a_2,a_3)))x_1^(a_1)x_2^(a_2)x_3^(a_3) = (x_1+x_2+x_3)^n`
Plug in `x_1=x_2=x_3=1`
`sum_(a_1+a_2+a_3=n)((n),((a_1,a_2,a_3)))=3^n`
4.18: Prove that `sum_(a_1+a_2+a_3=n)((n),((a_1,a_2,a_3)))(-1)^(a_2)=1`
Start with the multinomial theorem
`sum_(a_1+a_2+a_3=n)((n),((a_1,a_2,a_3)))x_1^(a_1)x_2^(a_2)x_3^(a_3) = (x_1+x_2+x_3)^n`
Plug in `x_1=x_3=1`, `x_2=-1`
`sum_(a_1+a_2+a_3=n)((n),((a_1,a_2,a_3)))(-1)^n=(1-1+1)^n`
`sum_(a_1+a_2+a_3=n)((n),((a_1,a_2,a_3)))(-1)^n=1`
4.25: Find a closed form for `sum_(n=1)^(oo)nx^(n-1)`
Since there's an `n` dropped down from the exponent, it looks like we have to take the derivative of `sum_(n=0)^(oo)x^n = 1/(1-x)`
Take out the constant term from `sum_(n=0)^(oo)x^n` in order to take the derivative
`sum_(n=0)^(oo)x^n=1+sum_(n=1)^(oo)x^n = 1/(1-x)`
Taking the derivative, we get
`sum_(n=1)^(oo)nx^(n-1) = color(red)(1/(1-x)^2)`
4.26: Prove that `1/sqrt(1-4x) = sum_(n ge 0)((2n),(n))x^n`
`1/sqrt(1-4x) = (1-4x)^(-1/2)`
`= sum_(n ge 0)((-1/2),(n))(-4x)^n`
`= sum_(n ge 0)((-1/2)(-3/2)(-5/2)...(-2n+1)/2)/(n!)(-1)^n2^(2n)x^n`
`= sum_(n ge 0)(1*3*5*...*(2n-1))/(n!)2^nx^n`
Now we have to show that `((2n),(n)) = ((2n)!)/(n!n!) = (1*3*5*...*(2n-1))/(n!)2^n`, which is the same as showing `((2n)!)/(n!) = 1*3*5*...*(2n-1)*2^n`
For `((2n)!)/(n!)`, all the terms on the bottom will divide all the even terms on top in half, resulting in `2^n` and all the odd terms leftover, which is `1*3*5*...*(2n-1)*2^n`
4.35: A school has `105` students and seven classes. If each student takes three classes, and each class is taken by the same number of students, how many students are taking each class?
Count the number of pairs `(x,c)` where `x` is a student and `c` is a class
There are `105*3 = 315` pairs
Distribute the pairs among `7` groups so that each group has the same number of pairs
So there are `color(red)(315/7 = 45)` students in each class
4.36: How many northeastern lattice paths are there from `(0,0)` to `(10,10)` that do not touch the point `(5,5)`, but do touch the point `(3,3)`?
Count the paths from `(0,0)` to `(3,3)`:
`((6),(3))`
(`6` steps total, choose `3` to be right/up)
Count the paths from `(3,3)` to `(10,10)`
`((14),(7))`
Since we can't go through `(5,5)`, count the number of paths going through `(5,5)` and subtract from the total number of paths
Paths from `(3,3)` to `(5,5)`:
`((4),(2))`
Paths from `(5,5)` to `(10,10)`
`((10),(5))`
Paths from `(3,3)` to `(10,10)` that go through `(5,5)`:
`((4),(2))*((10),(5))`
Paths from `(3,3)` to `(10,10)` that don't go through `(5,5)`:
`((14),(7))-((4),(2))*((10),(5))`
Paths from `(0,0)` to `(10,10)` that don't go through `(5,5)`:
`color(red)(((6),(3))*[((14),(7))-((4),(2))*((10),(5))])`
4.38: Prove that `((2n),(n)) = sum_(k=0)^n((n),(k))^2` for all positive integers `n`
Note that `((n),(k))^2 = ((n),(k))*((n),(k)) = ((n),(k))*((n),(n-k))`
The left-hand side is counting the number of ways to pick `n` people from a group of `2n` people
We could pick people another way by splitting the `2n` people into two groups of `n` people
Pick `k` people from the first group: `((n),(k))`
Now we have to pick `n-k` people from the second group: `((n),(n-k))`
Summing over all `k`, we get the result
`((2n),(n)) = sum_(k=0)^n((n),(k))*((n),(n-k))`
`((2n),(n)) = sum_(k=0)^n((n),(k))*((n),(k))`
`((2n),(n)) = sum_(k=0)^n((n),(k))^2`
4.39: Prove that `n((2n-1),(n-1)) = sum_(k=1)^nk((n),(k))^2` for all positive integers `n`
Note that `((n),(k))^2 = ((n),(k))*((n),(k)) = ((n),(k))*((n),(n-k))`
The left-hand side is counting the number of ways to form a group of `n` people with a leader from a group of `2n` people
First, pick the leader from `n` people, then pick `n-1` people from `2n-1` people to form the group
We could pick people another way by splitting the `2n` people into two groups of `n` people and picking a leader from the first group
Pick `k` people from the first group: `((n),(k))`
Pick a leader from the first group: there are `k` choices
Now we have to pick `n-k` people from the second group: `((n),(n-k))`
Summing over all `k`, we get the result
`n((2n-1),(n-1)) = sum_(k=1)^nk((n),(k))*((n),(n-k))`
`n((2n-1),(n-1)) = sum_(k=1)^nk((n),(k))*((n),(k))`
`n((2n-1),(n-1)) = sum_(k=1)^nk((n),(k))^2`
4.40: Prove that `3^n = sum_(k=0)^n2^k((n),(k))` for all positive integers `n`
Start with the binomial theorem:
`(x+y)^n = sum_(k=0)^n((n),(k))x^ky^(n-k)`
Plug in `x=2, y=1`:
`(2+1)^n = sum_(k=0)^n((n),(k))2^k1^(n-k)`
`3^n = sum_(k=0)^n((n),(k))2^k`
4.45: Prove that `sum_(k=0)^n((n),(k))2^k = (3^n+(-1)^n)/2` for all positive integers `n` and even `k`
(Refer to the trick for getting rid of even/odd terms of a formal power series in the egf section)
We can isolate the even terms by adding `sum_(k=0)^n((n),(k))(-2)^k` to `sum_(k=0)^n((n),(k))2^k`
`sum_(k=0)^n((n),(k))2^k = ((n),(0))2^0 + ((n),(1))2^1 + ((n),(2))2^2 + ((n),(3))2^3 + ...`
`sum_(k=0)^n((n),(k))(-2)^k = ((n),(0))(-2)^0 + ((n),(1))(-2)^1 + ((n),(2))(-2)^2 + ((n),(3))(-2)^3 + ...`
Notice that the terms with odd exponents will cancel out after addition, leaving
`2 + 2((n),(2))2^2 + 2((n),(4))2^4 + ...`
Dividing by `2` will give us
`1 + ((n),(2))2^2 + ((n),(4))2^4 + ...`
`= sum_(k=0)^n((n),(k))2^k` for even `k`
Using the binomial theorem, we can simplify `sum_(k=0)^n((n),(k))2^k` and `sum_(k=0)^n((n),(k))(-2)^k`
`sum_(k=0)^n((n),(k))2^k = (2+1)^n = 3^n`
`sum_(k=0)^n((n),(k))(-2)^k = (-2+1)^n = (-1)^n`
Adding those and dividing the sum by `2` gives us
`(3^n+(-1)^n)/2`
which is equal to `sum_(k=0)^n((n),(k))2^k` for even `k` as shown at the beginning
4.46: Prove that `sum_(k=1)^n((n),(k))5^k = (6^n-(-4)^n)/2` for all positive integers `n` and odd `k`
(Refer to the trick for getting rid of even/odd terms of a formal power series in the egf section)
We can isolate the odd terms by subtracting `sum_(k=0)^n((n),(k))(-5)^k` from `sum_(k=0)^n((n),(k))5^k`
`sum_(k=0)^n((n),(k))5^k = ((n),(0))5^0 + ((n),(1))5^1 + ((n),(2))5^2 + ((n),(3))5^3 + ...`
`sum_(k=0)^n((n),(k))(-5)^k = ((n),(0))(-5)^0 + ((n),(1))(-5)^1 + ((n),(2))(-5)^2 + ((n),(3))(-5)^3 + ...`
Notice that the terms with even exponents will cancel out after subtraction, leaving
`2((n),(1))5^1 + 2((n),(3))5^3 + ...`
Dividing by `2` will give us
`((n),(2))5^1 + ((n),(3))5^3 + ...`
`= sum_(k=1)^n((n),(k))5^k` for odd `k`
Using the binomial theorem, we can simplify `sum_(k=0)^n((n),(k))5^k` and `sum_(k=0)^n((n),(k))(-5)^k`
`sum_(k=0)^n((n),(k))5^k = (5+1)^n = 6^n`
`sum_(k=0)^n((n),(k))(-5)^k = (-5+1)^n = (-4)^n`
Adding those and dividing the sum by `2` gives us
`(6^n+(-4)^n)/2`
which is equal to `sum_(k=0)^n((n),(k))5^k` for odd `k` as shown at the beginning
4.49: What is the coefficient of `x^n` in the power series form of `root(3)(1-2x)`?
`root(3)(1-2x) = (1-2x)^(1/3)`
Start with the general binomial theorem:
`(1+x)^m = sum_(n ge 0)((m),(n))x^n`
Plug in `x=-2x` and `m=1/3`
`(1-2x)^(1/3) = sum_(n ge 0)((1/3),(n))(-2x)^n`
`(1-2x)^(1/3) = sum_(n ge 0)((1/3),(n))(-2)^nx^n`
So the coefficient of `x^n` is `color(red)(((1/3),(n))(-2)^n)`
8.1: Find an explicit formula for `a_k` if `a_0=0` and `a_(k+1)=a_k+2^k` for `k ge 0`
`a_1 = a_0 + 2^0 = 2^0`
`a_2 = a_1 + 2^1 = 2^0+2^1`
`a_3 = a_2 + 2^2 = 2^0+2^1+2^2`
`vdots`
`a_k = 2^0+2^1+2^2+...+2^(k-1) = sum_(i=0)^(k-1)2^i`
We can think of `sum_(i=0)^(k-1)2^i` as a binary digit with `k` `1`'s
`ubrace(111...111)_k`
Adding `1` to that binary digit results in a `1` followed by `k` `0`'s, which is `2^k`
`1ubrace(000...000)_k`
So `a_k = sum_(i=0)^(k-1)2^i = color(red)(2^k-1)`
8.4: A child wants to walk up a stairway. At each step, she moves up either one or two stairs. Let `f(n)` be the number of ways she can reach the `n^(th)` stair. Let `F(x) = sum_(n ge 0)f_nx^n` be the generating function. Express `F(x)` as a rational function
She can reach the `n^(th)` step from either the `(n-1)^(st)` step or the `(n-2)^(nd)` step
So `f(n) = f(n-1) + f(n-2) implies f(n+2) = f(n+1) + f(n)`
Let `f(0)=1`
Multiply the recurrence by `x^(n+2)` and sum over all `n ge 0`
`sum_(n ge 0)f(n+2)x^(n+2) = sum_(n ge 0)f(n+1)x^(n+2) + sum_(n ge 0)f(n)x^(n+2)`
`F(x)-f(0)-f(1)x = xsum_(n ge 0)f(n+1)x^(n+1) + x^2sum_(n ge 0)f(n)x^n`
`F(x)-1-x = x(F(x)-f(0)) + x^2F(x)`
`F(x)-1-x = xF(x)-x+x^2F(x)`
`F(x)-xF(x)-x^2F(x)=1`
`F(x)(1-x-x^2)=1`
`color(red)(F(x)=1/(1-x-x^2))`
8.7: Let `a_n` be the number of ways to pay `n` dollars using ten-dollar bills, five-dollar bills, and one-dollar bills only. Find the ordinary generating function `A(x) = sum_(n ge 0)a_nx^n`
Let `B(x)` be the generating function for the number of ways to pay `n` dollars using only ten-dollar bills
Let `C(x)` be the generating function for the number of ways to pay `n` dollars using only five-dollar bills
Let `D(x)` be the generating function for the number of ways to pay `n` dollars using only one-dollar bills
Then the product `B(x)C(x)D(x)` will be the number of ways to pay `n` dollars using those three types of bills
For `B(x)`, there are no ways to pay `n` dollars using only ten-dollar bills for `1 le n le 9`, `11 le n le 19`, ..., so
`B(x) = 1+0x+0x^2+...+1x^10+0x^11+...+1x^20+...=1+x^10+x^20+...=1/(1-x^10)`
Similarly for `C(x)` and `D(x)`
`C(x) = 1+x^5+x^10+...=1/(1-x^5)`
`D(x) = 1+x^1+x^2+...=1/(1-x)`
So `A(x)=B(x)C(x)D(x)=color(red)(1/((1-x^10)(1-x^5)(1-x)))`
8.8: Find a simple, closed form for the generating function of the sequence defined by `a_n=n^2`. Hint: `n^2 = 2((n),(2))+n`
Multiply the recurrence by `x^n` and sum over all `n`:
`sum_(n ge 0)a_nx^n = sum_(n ge 0)2((n),(2))x^n + sum_(n ge 0)nx^n`
Simplifying `((n),(2)) = (n*(n-1)*(n-2)!)/(2*(n-2)!) = (n(n-1))/2`, we get
`A(x) = sum_(n ge 2)n(n-1)x^n + sum_(n ge 1)nx^n`
`sum_(n ge 2)n(n-1)x^n` looks like a double derivative and `sum_(n ge 1)nx^n` looks like a derivative
`A(x) = sum_(n ge 0)a_nx^n = 1/(1-x)`
`A'(x) = sum_(n ge 1)na_nx^(n-1) = 1/(1-x)^2`
`A''(x) = sum_(n ge 2)a_n(n-1)x^(n-2) = 2/(1-x)^3`
Taking the derivatives and multiplying by `x` and `x^2` gives us
`A(x) = (2x^2)/(1-x)^3 + x/(1-x)^2`
`= color(red)((x(x+1))/(1-x)^3)`
8.9: Let `f(n)` be the number of subsets of `[n]` in which the distance of any two elements is at least three. Find the generating function of `f(n)`
Consider a subset that satisfies the condition
If `n` is part of the subset, then `n-1` and `n-2` cannot be in the subset
So there would be `f(n-3)` ways to make this subset
If `n` is not part of the subset, then there would be `f(n-1)` ways to make this subset
So we get the recurrence `f(n) = f(n-3)+f(n-1)` for `n ge 3`
`f(0) = 1` (just the empty set)
`f(1) = 2` (the empty set and `{1}`)
`f(2) = 3` (the empty set, `{1}` and `{2}`)
Multiply the recurrence by `x^n` and sum over all `n ge 3`
`sum_(n ge 3)f(n)x^n = sum_(n ge 3)f(n-3)x^n + sum_(n ge 3)f(n-1)x^n`
`F(x)-f(0)-f(1)x-f(2)x^2 = x^3sum_(n ge 3)f(n-3)x^(n-3) + xsum_(n ge 3)f(n-1)x^(n-1)`
`F(x)-1-2x-3x^2 = x^3F(x) + x(F(x)-f(0)-f(1)x)`
`F(x)-1-2x-3x^2 = x^3F(x) + xF(x)-x-2x^2`
`F(x)-x^3F(x)-xF(x) = 1+x+x^2`
`F(x)(1-x-x^3) = 1+x+x^2`
`F(x) = (1+x+x^2)/(1-x-x^3)`
8.22: Let `b(n)` be the number of compositions of `n` in which each part is an odd integer. Find a closed formula for `sum_(n ge 0)b(n)x^n`
Since the number of parts is unspecified, this problem involves a composition of generating functions
This is equivalent to splitting up `[n]` into intervals and covering each interval with a single tile of odd length
If the length of the interval is even, then there is no way to do this
If the length of the interval is odd, then there is one way to do this
`a_n = {(1 text( if n odd)),(0 text( if n even)):}`
So `A(x)=x+x^3+x^5+... = x(1+x^2+x^4+...) = x/(1-x^2)`
So `B(x) = 1/(1-A(x))`
`= 1/(1-x/(1-x^2))`
`= color(red)((1-x^2)/(1-x^2-x))`
8.23: Find an explicit formula for `a_n` if `a_0=1` and `a_(n+1)=3a_n+2^n` if `n ge 0`
Multiply the recurrence by `x^(n+1)` and sum over all `n ge 0`:
`sum_(n ge 0)a_(n+1)x^(n+1) = sum_(n ge 0)3a_nx^(n+1) + sum_(n ge 0)2^nx^(n+1)`
`A(x)-a_0 = 3xsum_(n ge 0)a_nx^n + xsum_(n ge 0)(2x)^n`
`A(x)-1 = 3xA(x)+x/(1-2x)`
`A(x)-3xA(x) = x/(1-2x)+1`
`A(x)(1-3x) = (1-x)/(1-2x)`
`A(x) = (1-x)/((1-2x)(1-3x))`
Using partial fractions, we get
`(1-x)/((1-2x)(1-3x)) = alpha/(1-2x) + beta/(1-3x)`
`1-x = (1-3x)alpha + (1-2x)beta`
`1-x = alpha-3alphax + beta-2betax`
`1-x = (alpha+beta)+(-3alpha-2beta)x`
`implies alpha=-1, beta=2`
`implies (1-x)/((1-2x)(1-3x)) = -1/(1-2x) + 2/(1-3x)`
`= 2sum_(n ge 0)(3x)^n - sum_(n ge 0)(2x)^n`
`= 2sum_(n ge 0)3^nx^n - sum_(n ge 0)2^nx^n`
So `a_n` is the coefficient of `x^n`, which is `color(red)(2*3^n-2^n)`
8.24: Find an explicit formula for `a_n` if `a_0=1,a_1=4` and `a_(n+2)=8a_(n+1)-16a_n` for `n ge 0`
We can use the characteristic polynomial `t^2-c_1t-c_2` where `c_1=8` and `c_2=-16`
`t^2-8t+16=(t-4)(t-4)`
Since the roots are the same there exist `alpha_1,alpha_2` such that `a_n = alpha_1 4^n+alpha_2n4^n`
Plugging in `n=0,1`:
`a_0 = 1 = alpha_1`
`a_1 = 4 = 4alpha_1 + 4alpha_2`
`implies alpha_1 = 1, alpha_2 = 0`
`implies a_n = color(red)(4^n)`
8.25: A certain kind of insect population multiplies so that at the end of each year, its size is the double of its size a year before, plus `1000` more insects. Assuming that originally we released `50` insects, how many of them will we have at the end of the `n^(th)` year?
The recurrence is `a_(n+1) = 2a_n + 1000` for `n ge 0` and `a_0=50`
Multiply the recurrence by `x^(n+1)` and sum over `n ge 0`:
`sum_(n ge 0)a_(n+1)x^(n+1) = sum_(n ge 0)2a_nx^(n+1) + sum_(n ge 0)1000x^(n+1)`
`A(x)-a_0 = 2xsum_(n ge 0)a_nx^n + 1000xsum_(n ge 0)x^n`
`A(x)-50 = 2xA(x) + (1000x)/(1-x)`
`A(x)-2xA(x) = (1000x)/(1-x)+50`
`A(x)(1-2x) = (50+950x)/(1-x)`
`A(x) = (50+950x)/((1-2x)(1-x))`
Using partial fractions, we get:
`(50+950x)/((1-2x)(1-x)) = alpha/(1-2x)+beta/(1-x)`
`50+950x = (1-x)alpha + (1-2x)beta`
`50+950x = alpha-alphax + beta-2betax`
`50+950x = (alpha+beta) + (-alpha-2beta)x`
`implies alpha=1050, beta=-1000`
`implies (50+950x)/((1-2x)(1-x)) = 1050/(1-2x)-1000/(1-x)`
`= 1050sum_(n ge 0)(2x)^n - 1000sum_(n ge 0)x^n`
`= 1050sum_(n ge 0)2^nx^n - 1000sum_(n ge 0)x^n`
So `a_n` is the coefficient of `x^n`, which is `color(red)(1050*2^n-1000)`
8.27: Find an explicit formula for the numbers `a_n` if `a_(n+1) = (n+1)a_n + 2(n+1)!` if `n ge 0` and `a_0 = 0`
Since there's an `(n+1)!`, we should probably use exponential generating functions
Let `A(x) = sum_(n ge 0)a_n/(n!)x^n`
Multiply both sides by `x^(n+1)/((n+1)!)` and sum over `n ge 0`
`sum_(n ge 0)a_(n+1)/((n+1)!)x^(n+1) = sum_(n ge 0)((n+1)a_n)/((n+1)!)x^(n+1) + sum_(n ge 0)(2(n+1)!)/((n+1)!)x^(n+1)`
`A(x)-a_0 = sum_(n ge 0)a_n/(n!)x^(n+1) + sum_(n ge 0)2x^(n+1)`
`A(x) = xsum_(n ge 0)a_n/(n!)x^n + 2xsum_(n ge 0)x^n`
`A(x) = xA(x) = (2x)/(1-x)`
`A(x)-xA(x) = (2x)/(1-x)`
`A(x)(1-x) = (2x)/(1-x)`
`A(x) = (2x)/(1-x)^2`
`A(x) = 2x(1-x)^(-2)`
`A(x) = 2xsum_(n ge 0)((n+1),(n))x^n`
`A(x) = 2sum_(n ge 0)((n+1),(n))x^(n+1)`
`A(x) = 2sum_(n ge 1)((n),(n-1))x^n`
`A(x) = 2sum_(n ge 1)(n!)/((n-1)!1!)x^n`
`A(x) = 2sum_(n ge 1)(n*n!)/(n!)x^n`
`A(x) = 2sum_(n ge 0)(n*n!)/(n!)x^n`
So `color(red)(a_n = 2n(n!))`
8.34: Let `h_0=1`, and let `h_n` be the number of compositions of `n` into parts equal to `2` or `3`. Find a closed formula for `H(x)=sum_(n ge 0)h_nx^n`
Consider removing the `n^(th)` part of the composition
If it was of size `2`, then there are `h_(n-2)` ways to get a composition of `n`
If it was of size `3`, then there are `h_(n-3)` ways to get a composition of `n`
So we get the recurrence `h_n = h_(n-2)+h_(n-3)` for `n ge 3` and `h_0=1, h_1=0, h_2=1`
Multiply the recurrence by `x^n` and sum over all `n ge 3`:
`sum_(n ge 3)h_nx^n = sum_(n ge 3)h_(n-2)x^n + sum_(n ge 3)h_(n-3)x^n`
`H(x)-h_0-h_1x-h_2x^2 = x^2sum_(n ge 3)h_(n-2)x^(n-2) + x^3sum_(n ge 3)h_(n-3)x^(n-3)`
`H(x)-1-x^2 = x^2(H(x)-h_0) + x^3H(x)`
`H(x)-1-x^2 = x^2H(x)-x^2+x^3H(x)`
`H(x)-x^2H(x)-x^3H(x) = 1`
`H(x)(1-x^2-x^3) = 1`
`H(x) = color(red)(1/(1-x^2-x^3))`
Alternatively, since the number of parts are unspecified, we could compose generating functions
Let `h_n` be the number of ways to break up `[n]` into consecutive intervals of sizes `2` and `3`
Let `alpha` be the ways to create a set of size `2` or `3`
So `a_2=a_3=1` and `a_n = 0` for `n != 2,3`
So `A(x) = sum_(n ge 0)a_nx^n = x^2+x^3`
`H(x) = 1/(1-A(x)) = color(red)(1/(1-x^2-x^3))`
8.35: Let `H_n` be the number of ways to tile a `1xxn` rectangle with `1xx1` tiles that are red or blue and `1xx2` tiles that are green, yellow, or white. Find a closed formula for `H(x)=sum_(n ge 0)h_nx^n`
Consider removing the `n^(th)` tile
If it was a `1xx1` tile, then there are `2` ways to create the rectangle
If it was a `1xx2` tile, then there are `3` ways to create the rectangle
So we get the recurrence `h_n = 2h_(n-1)+3h_(n-2)` for `n ge 2` and `h_0=1, h_1=2`
Multiply the recurrence by `x^n` and sum over all `n ge 2`:
`sum_(n ge 2)h_nx^n = sum_(n ge 2)2h_(n-1)x^n + sum_(n ge 2)3h_(n-2)x^n`
`H(x)-h_0-h_1x = 2xsum_(n ge 2)h_(n-1)x^(n-1) + 3x^2sum_(n ge 2)h_(n-2)x^(n-2)`
`H(x)-1-2x = 2x(H(x)-h_0) + 3x^2H(x)`
`H(x)-1-2x = 2xH(x)-2x+3x^2H(x)`
`H(x)-2xH(x)-3x^2H(x) = 1`
`H(x)(1-2x-3x^2) = 1`
`H(x) = color(red)(1/(1-2x-3x^2))`
8.36: Let `h_n` be the number of sequences of length `n` consisting of letters `A` and `B` in which there is no subsequence of two letters `A` in consecutive positions. Find a closed formula for `H(x)=sum_(n ge 0)h_nx^n`
Consider the last letter of the sequence
If it is a `B`, then there are `h_(n-1)` ways to form this sequence
If it is an `A`, then there are `h_(n-2)` ways to form this sequence because the second to last letter must be a `B`
So we get the recurrence `h_n = h_(n-1) + h_(n-2)` where `h_0 = 1` and `h_1 = 2`
Multiply the recurrence by `x_n` and sum over all `n ge 2`:
`sum_(n ge 2)h_nx^n = sum_(n ge 2)h_(n-1)x^n + sum_(n ge 2)h_(n-2)x^n`
`H(x)-h_0-h_1x = xsum_(n ge 2)h_(n-1)x^(n-1) + x^2sum_(n ge 2)h_(n-2)x^(n-2)`
`H(x)-1-2x = x(H(x)-h_0) + x^2H(x)`
`H(x)-1-2x = xH(x)-x + x^2H(x)`
`H(x)-xH(x)-x^2H(x) = 1+x`
`H(x)(1-x-x^2) = 1+x`
`H(x) = color(red)((1+x)/(1-x-x^2))`
8.39: Let `t_n` be the number of ways to arrange `n` books on two bookshelves so that each shelf receives at least one book. Find a closed formula for `t_n`
We want to split up the books into two nonempty subsets and order the books in each subset
Let `a_n` be the number of ways to order the books in the first shelf
Let `b_n` be the number of ways to order the books in the second shelf
`a_n = b_n = {(0\ text(if ) n = 0), (n!\ text(if ) n ge 0):}`
`t_n` is the coefficient of `x^n/(n!)` in the product `A(x)B(x)`
`= (sum_(n ge 0)a_n/(n!)x^n)(sum_(n ge 0)b_n/(n!)x^n)`
`= (sum_(n ge 1)a_n/(n!)x^n)(sum_(n ge 1)b_n/(n!)x^n)`
`= (sum_(n ge 1)(n!)/(n!)x^n)(sum_(n ge 1)(n!)/(n!)x^n)`
`= (sum_(n ge 1)x^n)(sum_(n ge 1)x^n)`
`= (xsum_(n ge 1)x^(n-1))(xsum_(n ge 1)x^(n-1))`
`= (xsum_(n ge 0)x^n)(xsum_(n ge 0)x^n)`
`= (x/(1-x))(x/(1-x))`
`= x^2(1-x)^(-2)`
`= x^2sum_(n ge 0)((-2),(n))(-x)^n`
`= x^2sum_(n ge 0)((n+1),(n))(-1)^n(-1)^nx^n`
`= x^2sum_(n ge 0)(n+1)x^n`
`= sum_(n ge 0)(n+1)x^(n+2)`
`= sum_(n ge 2)(n-1)x^n`
`= sum_(n ge 2)(n!(n-1))/(n!)x^n`
So `color(red)(t_n = n!(n-1))` for `n ge 2` and `color(red)(t_0 = t_1 = 0)`
8.43: We divide a group of people into subgroups `A`, `B`, and `C`, and ask each subgroup to form a line. We also require that `A` have an odd number of people, and that `B` have an even number of people. How many ways are there to do this?
Let `a_n` be the number of ways to order the people in `A` in a line
Let `b_n` be the number of ways to order the people in `B` in a line
Let `c_n` be the number of ways to order the people in `C` in a line
`a_n = {(n! text( if ) n text( odd)),(0 text( if ) n text( even)):}`
`b_n = {(n! text( if ) n text( even)),(0 text( if ) n text( odd)):}`
`c_n = n!`
The answer is the coefficient of `x^n/(n!)` in the product `A(x)B(x)C(x)`
`=(sum_(n ge 0)a_n/(n!)x^n)(sum_(n ge 0)c_n/(n!)x^n)(sum_(n ge 0)c_n/(n!)x^n)`
`=(sum_(n text( odd ))(n!)/(n!)x^n)(sum_(n text( even ))(n!)/(n!)x^n)(sum_(n ge 0)(n!)/(n!)x^n)`
`=(sum_(n text( odd ))x^n)(sum_(n text( even ))x^n)(sum_(n ge 0)x^n)`
`=(sum_(n ge 0)x^(2n+1))(sum_(n ge 0)x^(2n))(sum_(n ge 0)x^n)`
`=(xsum_(n ge 0)x^(2n))(sum_(n ge 0)x^(2n))(sum_(n ge 0)x^n)`
`=(x/(1-x^2))(1/(1-x^2))(1/(1-x))`
And use partial fraction decomposition to continue
8.44: We select an odd number of people from a group of `n` people to serve on a committee. Then we select an even number from this committee to serve on a subcommittee. In how many different ways can we do this?
This is the same problem as picking subsets `A sube B sube [n]` such that `A` is even, `B\\A` is odd, and `[n]\\B` can be even or odd
(We frame the problem this way to set the problem up with disjoint sets whose union is the whole set)
Let `a_n` be the number of ways for a subset to be even
Let `b_n` be the number of ways for a subset to be odd
Let `c_n` be the number of ways for a subset to be of size `n`
`a_n = {(1 text( if ) n text( even)), (0 text( if ) n text( odd)):}`
`b_n = {(1 text( if ) n text( odd)), (0 text( if ) n text( even)):}`
`c_n = 1`
The answer is the coefficient of `x^n/(n!)` in the product `A(x)B(x)C(x)`
`= (sum_(n ge 0)a_n/(n!)x^n)(sum_(n ge 0)b_n/(n!)x^n)(sum_(n ge 0)c_n/(n!)x^n)`
`= (sum_(n text( even))1/(n!)x^n)(sum_(n text( odd))1/(n!)x^n)(sum_(n ge 0)1/(n!)x^n)`
`= ((e^x+e^(-x))/2)((e^x-e^(-x))/2)(e^x)`
`= ((e^(2x)-e^(-2x))/4)e^x`
`= 1/4(e^(3x)-e^(-x))`
`= 1/4(sum_(n ge 0)1/(n!)(3x)^n - sum_(n ge 0)1/(n!)(-x)^n)`
`= 1/4(sum_(n ge 0)1/(n!)3^nx^n - sum_(n ge 0)1/(n!)(-1)^nx^n)`
The coefficient of `x^n/(n!)` is `color(red)(1/4(3^n-(-1)^n))`
8.45: We have `n` cards. We want to split them into an even number of non-empty subsets, form a line within each subset, then arrange the subsets in a line. In how many different ways can we do this?
Let `a_n` be the number of ways to form a line of cards
Let `b_n` be the number of ways to form a line of subsets
Let `c_n` be the answer to the problem
`a_n = {(0 text( if ) n = 0),(n! text( if ) n gt 0):}`
`b_n = {(0 text( if ) n text ( odd)),(n! text( if ) n text( even)):}`
So the exponential generating functions are
`A(x) = sum_(n ge 0)a_n/(n!)x^n = sum_(n ge 1)x^n = x/(1-x)`
`B(x) = sum_(n ge 0)b_n/(n!)x^n = sum_(n ge 0)x^2n = 1/(1-x^2)`
The answer is the coefficient of `x^n/(n!)` in the composition `B(A(x))`
`= 1/(1-(x/(1-x))^2)`
`= (1-x)^2/((1-x)^2-x^2)`
`= (1-2x+x^2)/(1-2x)`
`= 1 + x^2/(1-2x)`
`= 1 + x^2sum_(n ge 0)(-2x)^n`
`= 1 + x^2sum_(n ge 0)(-2)^nx^n`
`= 1 + sum_(n ge 0)(-2)^nx^(n+2)`
`= 1 + sum_(n ge 2)(-2)^(n-2)x^n`
`= 1 + sum_(n ge 2)n!(-2)^(n-2)x^n/(n!)`
So `c_n = color(red)(n!(-2)^(n-2))` for `n ge 2`
`c_0` is the constant term, which is `1`
`c_1` is the linear term, which is `0`
8.49:
(a) Let `a_1,a_2,...,a_k` be nonnegative integers, and let `a(n)` be the number of compositions of `n` into `k` parts so that the `i^(th)` part is not larger than `a_i`. Find the ordinary generating function `A(x)=sum_(n ge 0)a(n)x^n`
(b) Let `b(n)` be the number of compositions of `n` into `k+1` parts so that the `i^(th)` part is not larger than `a_i`, and there is no constraint on the last part. Find the ordinary generating function `B(x) = sum_(n ge 0)b(n)x^n`
Since the number of parts is specified, this problem involves multiplying generating functions
(a) This problem is the same as splitting up `[n]` into `k` consecutive intervals such that the `i^(th)` interval has size `ge 1` and `le a_i`
So `A(x) = A_1(x)A_2(x)...A_k(x)` where `A_i(x)` encodes the conditions on the `i^(th)` interval
`A_i(x) = x + x^2 + ... + x^(a_i) = x(1+x+...+x^(a_i-1))`
So `A(x) = prod_(i=1)^k x(1+x+...+x^(a_i-1)) = color(red)(prod_(i=1)^k x(1-x^(a_i))/(1-x))`
(b) With the same constraints on `1 le i le k`, we have
`B(x) = A_1(x)A_2(x)...A_k(x)A_(k+1)(x)`
Since there is no constraint for the `(k+1)^(st)` part, we have
`A_(k+1) = x + x^2 + ... = x(1 + x + x^2 + ...) = x1/(1-x)`
So `B(x) = color(red)((xA(x))/(1-x))`
7.3: How many positive integers `k le 210` are relatively prime to `210`?
We can count the number of integers that are not relatively prime to `210` and subtract that from `210`
An integer is not relatively prime to `210` if it is divisible by `2` or `3` or `5` or `7`
Let `A_2` be the set of integers divisible by `2`
Let `A_3` be the set of integers divisible by `3`
Let `A_5` be the set of integers divisible by `5`
Let `A_7` be the set of integers divisible by `7`
Then the set of all integers relatively prime to `210` are in the union `A_2 uu A_3 uu A_5 uu A_7`
By inclusion-exclusion, `|A_2 uu A_3 uu A_5 uu A_7|`
`= |A_2| + |A_3| + |A_5| + |A_7|`
`- |A_2 nn A_3| - |A_2 nn A_5| - |A_2 nn A_7| - |A_3 nn A_5| - |A_3 nn A_7| - |A_5 nn A_7|`
`+ |A_2 nn A_3 nn A_5| + |A_2 nn A_3 nn A_7| + |A_2 nn A_5 nn A_7| + |A_3 nn A_5 nn A_7|`
`- |A_2 nn A_3 nn A_5 nn A_7|`
There are `210/2 = 105` integers divisible by `2`, so `|A_2| = 105`
There are `210/(2*3) = 35` integers divisible by `2` and `3`, so `|A_2 nn A_3| = 35`
(A number divisible by `2` and `3` is divisible by `6`)
There are `210/(2*3*5) = 7` integers divisible by `2` and `3` and `5`, so `|A_2 nn A_3 nn A_5| = 7`
So the number of integers not relatively prime to `210` is
`105+70+42+30-35-21-15-14-10-6+7+5+3+2-1 = 162`
The number of integers relatively prime to `210` is
`210-162 = color(red)(48)`
7.4: Let `m` be a positive integer. Denote by `phi(m)` the number of integers in `[m]` that are relatively prime to `m`. Let `p,q,r` be distinct prime numbers. Compute `phi(pqr)`
We can count the number of integers that are not relatively prime to `pqr` and subtract that from `pqr`
An integer is not relatively prime to `pqr` if it is divisible by `p` or `q` or `r`
Let `A_p` be the set of integers divisible by `p`
Let `A_q` be the set of integers divisible by `q`
Let `A_r` be the set of integers divisible by `r`
Then the set of all integers relatively prime to `pqr` are in the union `A_p uu A_q uu A_r`
By inclusion-exclusion, `|A_p uu A_q uu A_r|`
`= |A_p| + |A_q| + |A_r| - |A_p nn A_q| - |A_p nn A_r| - |A_q nn A_r| + |A_p nn A_q nn A_r|`
`= qr + pr + pq - r - q - p + 1`
which is the number of integers not relatively prime to `pqr`
So the number of integers relatively prime to `pqr` is
`color(red)(pqr - qr - pr - pq + r + q + p - 1) = (p-1)(q-1)(r-1)`
7.13: Let `p = p_1p_2...p_n` be an `n`-permutation, and assume `n ge 3`. `i` is an excedence of `p` if `p_i gt i`. Compute the number of `n`-permutations whose excedence set contains at least one of `n-2` and `n-1`
Let `A_(n-1)` be the set of `n`-permutations whose excedence set contains only `n-1`
Let `A_(n-2)` be the set of `n`-permutations whose excedence set contains only `n-2`
Then the number of `n`-permutations whose excedence set contains at least one of `n-2` and `n-1` is the union `A_(n-1) uu A_(n-2)`
By inclusion-exclusion, `|A_(n-1) uu A_(n-2)|`
`= |A_(n-1)| + |A_(n-2)| - |A_(n-1) nn A_(n-2)|`
For `n-1` to be an excedence, the number at the `(n-1)^(st)` spot has to be bigger than `n-1`. There is only one number (`n`) bigger than `n-1`, so there is only one choice for `p_(n-1)`. There are `n-1` remaining numbers for the rest of the spots, so `|A_(n-1)| = (n-1)!`
For `n-2` to be an excedence, the number at the `(n-2)^(nd)` spot has to be bigger than `n-2`. There are two numbers (`n` and `n-1`) bigger than `n-2`, so there are two choices for `p_(n-2)`. There are `n-1` remaining numbers for the rest of the spots, so `|A_(n-2)| = 2(n-1)!`
For `n-1` and `n-2` to be an excedence, the number at the `(n-1)^(th)` spot has to be bigger than `n-1` and the number at the `(n-2)^(nd)` spot has to be bigger than `n-2`. `p_(n-1)` is forced to be `n`, which forces `p_(n-2)` to be `n-1`. There are `n-2` remaining numbers for the rest of the spots, so `|A_(n-1) nn A_(n-2)| = (n-2)!`
So the number of `n`-permutations whose excedence set contains at least one of `n-2` and `n-1` is
`(n-1)! + 2(n-1)! - (n-2)!`
`= color(red)(3(n-1)! - (n-2)!)`
7.15: How many partitions of `[n]` contain at least one of the singleton blocks `{1}` and `{n}`?
Let `A_1` be the set of partitions containing the singleton block `{1}`
Let `A_n` be the set of partitions containing the singleton block `{n}`
The set of partitions containing at least one of the singleton blocks is the union `A_1 uu A_n`
By inclusion-exclusion, `|A_1 uu A_n|`
`= |A_1| + |A_n| - |A_1 nn A_n|`
For `A_1`, we put `1` in its own block. Then there are `n-1` numbers to put into blocks, which is counted by `B(n-1)`
For `A_1 nn A_n`, we put `1` and `n` in their own blocks. Then there `n-2` numbers to put into blocks, which is counted by `B(n-2)`
So the number of partitions that contain at least one of the singleton blocks `{1}` and `{n}` is
`B(n-1) + B(n-1) - B(n-2)`
`= color(red)(2B(n-1) - B(n-2))`
7.17: How many compositions does `n` have in which neither the first nor the last entry is `1`?
Count the number of compositions that have a `1` in the first entry or a `1` in the last entry and subtract from the total number of compositions
Let `A_1` be the set of compositions that have a `1` in the first entry
Let `A_2` be the set of compositions that have a `1` in the last entry
Then the set of compositions in which the first or last entry is a `1` is the union `A_1 uu A_2`
By inclusion-exclusion, `|A_1 uu A_2|`
`= |A_1| + |A_2| - |A_1 nn A_2|`
For `A_1`, since there is a `1` in the first entry, the problem turns into compositions of `n-1`, of which there are `2^(n-1-1) = 2^(n-2)`
For `A_1 nn A_2`, since there is are `1`'s in the first and last entry, the problem turns into compositions of `n-2`, of which there are `2^(n-2-1) = 2^(n-3)`
So the number of compositions in which the first or last entry is a `1` is
`2^(n-2) + 2^(n-2) - 2^(n-3)`
`= 2*2^(n-2) - 2^(n-3)`
`= 2^(n-1) - 2^(n-3)`
The number of compositions in which neither the first nor last entry is `1` is
`2^(n-1) - 2^(n-1) + 2^(n-3)`
`= color(red)(2^(n-3))`
7.20: Let `D(n)` be the number of derangements of a set of size `n`. Give a combinatorial proof of the identity `D(n+1) = n(D(n)+D(n-1))` for `n ge 1`
Consider the set `[n+1]`
Consider the number `n+1`. There are `n` choices for it
Suppose `n+1` is mapped to `i`
If `i` is not mapped to `n+1`, then we are now looking at derangements of a set of size `n`, which is `D(n)`
If `i` is mapped to `n+1`, then we are now looking at derangements of a set of size `n-1`, which is `D(n-1)`
So the number of derangements for a set of size `n+1` is `n(D(n)+D(n-1))`
7.24: How many three-digit positive integers are divisible by at least one of six and seven?
Let `A_6` be the set of integers divisible by six
Let `A_7` be the set of integers divisible by seven
Then the set of integers divisible by six or seven is the union `A_6 uu A_7`
By inclusion-exclusion, `|A_6 uu A_7|`
`= |A_6| + |A_7| - |A_6 nn A_7|`
There are `900/6 = 150` integers divisible by six, so `|A_6| = 150`
There are `lfloor900/7rfloor = 128` integers divisible by seven, so `|A_7| = 128`
There are `lfloor900/42rfloor = 21` integers divisible by six and seven, so `|A_6 nn A_7| = 21`
So the number of integers divisible by at least one of six and seven is
`150 + 128 - 21 = color(red)(257)`
7.25: How many two-digit positive integers are relatively prime to both two and three?
Count the number of integers not relatively prime to two or three and subtract from the total number of two-digit positive integers
Let `A_2` be the set of integers divisible by two
Let `A_3` be the set of integers divisible by three
Then the set of integers divisible by two or three is the union `A_2 uu A_3`
By inclusion-exclusion, `|A_2 uu A_3|`
`= |A_2| + |A_3| - |A_2 nn A_3|`
There are `90/2 = 45` integers divisible by two, so `|A_2| = 45`
There are `90/3 = 30` integers divisible by three, so `|A_3| = 30`
There are `90/6 = 15` integers divisible by two and three, so `|A_2 nn A_3| = 15`
So the number of integers divisible by two or three is
`45 + 30 - 15 = 60`
The number of two-digit positive integers that are relatively prime to both two and three is
`90 - 60 = color(red)(30)`
7.26: In how many ways can we list the digits `{1,1,2,2,3,4,5}` so that two identical digits are not in consecutive positions?
Count the number of arrangements that have consecutive `1`'s or consecutive `2`'s and subtract from the total number of arrangements
Let `A_1` be the set of arrangements that have consecutive `1`'s
Let `A_2` be the set of arrangements that have consecutive `2`'s
Then the set of arrangements that have consecutive `1`'s or consecutive `2`'s is the union `A_1 uu A_2`
By inclusion-exclusion, `|A_1 uu A_2|`
`= |A_1| + |A_2| - |A_1 nn A_2|`
We can combine the two `1`'s into one `1` since they have to go together
Then there are `(6!)/(2!)` ways to arrange the numbers, so `|A_1| = (6!)/(2!)
We can also combine the two `2`'s into one `2` since they have to go together
Then there are `5!` ways to arrange the numbers, so `|A_1 nn A_2| = 5!`
So the number of arrangements that have consecutive `1`'s or consecutive `2`'s is
`(6!)/(2!) + (6!)/(2!) - 5!`
`= 2(6!)/(2!) - 5!`
`= 6! - 5!`
The number of arrangements that don't have consecutive `1`'s and `2`'s is
`color(red)(7! - 6! + 5!)`
7.27: How many positive integers are there that are not larger than `1000` and are neither perfect squares nor perfect cubes?
Count the number of integers that are perfect squares or perfect cubes and subtract from the total number of integers
Let `A_2` be the set of perfect squares
Let `A_3` be the set of perfect cubes
Then the set of perfect squares or perfect cubes is the union `|A_2 uu A_3|`
By inclusion-exclusion, `|A_2 uu A_3|`
`= |A_2| + |A_3| - |A_2 nn A_3|`
There are `lfloorsqrt(1000)rfloor = 31` perfect squares, so `|A_2| = 31`
There are `root(3)(1000) = 10` perfect cubes, so `|A_3| = 10`
A perfect square that is also a perfect cube is a number that has the form `(x^2)^3 = x^6`
There are `lfloorroot(6)(1000)rfloor = 3` numbers that are perfect squares and perfect cubes
So the number of integers that are perfect squares or perfect cubes is
`31 + 10 - 3 = 38`
The number of integers that are neither perfect squares nor perfect cubes is
`1000 - 38 = color(red)(962)`