Ball and Box: Two Perspectives of Backtracking Enumeration
This article will resolve
LeetCode | Difficulty |
---|---|
46. Permutations | 🟠 |
78. Subsets | 🟠 |
Prerequisites
Before reading this article, you should familiarize yourself with:
Before diving into this article, you need to be familiar with the Backtracking Algorithm Core Framework and Backtracking Algorithm to Solve All Permutations/Combinations/Subsets.
In these two articles, readers have suggested different ways to write permutation/combination/subset code, such as using swap
to achieve full permutations and subset solutions without for loops. I previously avoided discussing these alternative methods to maintain consistency in problem-solving approaches. Introducing too many options early on can be confusing.
In this article, I will not only introduce the backtracking algorithm methods I haven't covered before but also explain why they work and what the essential differences are between the two approaches.
Key Takeaways
The essence of the backtracking algorithm's exhaustive thinking is the "Ball-Box Model." All backtracking algorithms stem from this model; there is no other way.
The Ball-Box Model inherently offers two exhaustive perspectives: the "ball" perspective and the "box" perspective, corresponding to two different coding approaches.
Theoretically, both perspectives are fundamentally the same. However, in terms of specific code implementation, one method may be more efficient than the other. You should choose the more efficient approach.
The term "Ball-Box Model" is something I coined casually. I will use the "ball" and "box" perspectives to explain, so just understand the concept.
Brute-Force Enumeration Method: The Ball and Box Model
All brute-force enumeration algorithms start with the ball and box model, without exception.
Once you understand this, you can effortlessly apply brute-force enumeration algorithms. Please read the following content carefully and think deeply.
First, let's review some previously learned knowledge about permutations and combinations:
P(n, k)
(often written asA(n, k)
in many texts) represents the total number of permutations (or arrangements) of selectingk
elements fromn
distinct elements;C(n, k)
represents the total number of combinations of selectingk
elements fromn
distinct elements.The main difference between "permutation" and "combination" is whether the order of elements is considered.
The formulas for calculating the total number of permutations and combinations:
data:image/s3,"s3://crabby-images/5e81d/5e81d8495b06ff8f5c077bf17d38556427a8bcd7" alt=""
Permutation P(n, k)
Now, let me ask a question: how is the permutation formula P(n, k)
derived? To clarify this, I need to discuss some concepts from combinatorial mathematics.
Various variations of permutation and combination problems can be abstracted into the "ball and box model." The permutation P(n, k)
can be represented by the following scenario:
data:image/s3,"s3://crabby-images/bb098/bb0988c2be0a16a1149aee9aaa85ad8b4e2c485a" alt=""
That is, placing n
balls, each with a different number to indicate order, into k
boxes, each also numbered differently (where n >= k
, and each box ends up with exactly one ball). There are P(n, k)
different ways to do this.
Now, when you place balls into boxes, how would you do it? There are two perspectives to consider.
First, from the perspective of the boxes, each box must choose one ball.
In this view, the first box can choose any of the n
balls, and then the remaining k - 1
boxes need to choose from the n - 1
balls left (this is the subproblem P(n - 1, k - 1)
):
data:image/s3,"s3://crabby-images/10d6c/10d6c5346c2dce1358485e5060d49aa5aa925b4d" alt=""
Alternatively, from the perspective of the balls, not every ball will be placed in a box, so there are two situations:
The first ball might not be placed in any box, leaving you to place the remaining
n - 1
balls intok
boxes.The first ball could be placed in any of the
k
boxes, so you would then place the remainingn - 1
balls intok - 1
boxes.
Combining these two situations, we obtain:
data:image/s3,"s3://crabby-images/35ab4/35ab4976f7f033b0f18ddac6ec1ae557eb6e13ac" alt=""
As you can see, the two perspectives yield two different recursive formulas, but both lead to the factorial form we are familiar with:
data:image/s3,"s3://crabby-images/072ee/072ee3e0c6131710c82e568cdec0e289ce335a25" alt=""
The process of solving these recursive formulas involves more mathematical content, which we will not delve into here. Interested readers are encouraged to study combinatorial mathematics on their own.