[
    {
        "problem_id": 446,
        "domain": [
            "Mathematics -> Discrete Mathematics -> Combinatorics"
        ],
        "difficulty": 5.0,
        "problem_text": "Consider the cube whose vertices are the eight points $(x, y, z)$ for which each of $x, y$, and $z$ is either 0 or 1 . How many ways are there to color its vertices black or white such that, for any vertex, if all of its neighbors are the same color then it is also that color? Two vertices are neighbors if they are the two endpoints of some edge of the cube.",
        "sample_id": 1,
        "final_answer": "The final answer is \\boxed{118}",
        "steps": [
            {
                "step_id": 1,
                "edge": "We begin by establishing the vertex set of the cube as given in the problem statement. Each vertex corresponds to a unique combination of binary coordinates (0 or 1) for x, y, and z, resulting in exactly 8 vertices. This foundational description is provided directly by the problem and serves as the basis for all subsequent combinatorial reasoning about adjacency and coloring.",
                "direct_dependent_steps": null,
                "node": "The cube has 8 vertices given by points $(x,y,z)$ where each of $x,y,z$ equals 0 or 1."
            },
            {
                "step_id": 2,
                "edge": "Building on the vertex definition from Step 1, we partition the vertices based on the parity of the sum x+y+z modulo 2. This defines set A as vertices with even parity (sum ≡ 0 mod 2), which is a natural bipartition for the cube graph since flipping any single coordinate changes the parity. This partitioning leverages modular arithmetic to create a structural framework essential for analyzing adjacency relationships.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Define $A$ as the set of vertices with $x+y+z\\equiv0\\pmod2$."
            },
            {
                "step_id": 3,
                "edge": "Similarly to Step 2, we define set B using the complementary parity condition (sum ≡ 1 mod 2) for the same vertex coordinates from Step 1. This creates a disjoint partition where every vertex belongs to exactly one set, forming the two parts of the cube's bipartite graph structure. The definition follows directly from modular arithmetic properties applied to the coordinate sums.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Define $B$ as the set of vertices with $x+y+z\\equiv1\\pmod2$."
            },
            {
                "step_id": 4,
                "edge": "Using the parity definition from Step 2, we count the vertices in set A. For three binary coordinates, exactly half of the 8 vertices have even parity (e.g., (0,0,0), (0,1,1), (1,0,1), (1,1,0)), yielding 4 vertices. This is verified by enumerating all combinations or recognizing the symmetry in binary sums—each parity class must contain an equal number of vertices for an odd number of dimensions.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "The set $A$ contains 4 vertices."
            },
            {
                "step_id": 5,
                "edge": "Following the same logic as Step 4 but for the odd parity condition in Step 3, set B must also contain 4 vertices. Since the total vertices are 8 (Step 1) and A and B form a disjoint partition (Steps 2-3), the count for B is necessarily 8 - 4 = 4. This symmetry between parity classes is inherent in the cube's structure.",
                "direct_dependent_steps": [
                    3
                ],
                "node": "The set $B$ contains 4 vertices."
            },
            {
                "step_id": 6,
                "edge": "From Step 2 and Step 3, adjacent vertices differ in exactly one coordinate, which flips the parity of x+y+z. Thus, any edge must connect a vertex from A (even parity) to one from B (odd parity). This establishes the cube as a bipartite graph with partitions A and B, a critical property that simplifies the coloring analysis by decoupling dependencies between the sets.",
                "direct_dependent_steps": [
                    2,
                    3
                ],
                "node": "Each edge of the cube connects exactly one vertex in $A$ to one vertex in $B$."
            },
            {
                "step_id": 7,
                "edge": "This step states the basic coloring rule: each vertex independently receives one of two colors (black or white). This is background knowledge about graph coloring problems, where color assignments are unrestricted except for any problem-specific constraints. It sets the stage for applying the problem's unique adjacency condition.",
                "direct_dependent_steps": null,
                "node": "A valid coloring assigns each vertex a color black or white."
            },
            {
                "step_id": 8,
                "edge": "The core constraint is stated here: if all neighbors of a vertex share a color, that vertex must match it. This is a local consistency condition derived from the problem statement, not an external theorem. It prevents isolated vertices from having a color different from their uniformly colored neighborhood, which will drive the forced colorings analyzed in later steps.",
                "direct_dependent_steps": null,
                "node": "The condition requires that if all neighbors of any vertex have the same color then that vertex must have that color."
            },
            {
                "step_id": 9,
                "edge": "To systematically handle the constraint from Step 8, we stratify valid colorings by the number of black vertices in set A (defined in Step 2). This casework approach is justified because the bipartite structure (Step 6) means color choices in A directly influence forced colors in B. Step 7 confirms color assignments are well-defined, making this partitioning both exhaustive and mutually exclusive.",
                "direct_dependent_steps": [
                    2,
                    7
                ],
                "node": "We perform casework on the number of black vertices in $A$."
            },
            {
                "step_id": 10,
                "edge": "Focusing on the first case from Step 9, we consider when all 4 vertices in A (Step 4) are black. This is a specific subcase of the casework strategy, chosen because extreme values (all black or all white) often yield straightforward forced colorings in constraint problems, simplifying initial analysis.",
                "direct_dependent_steps": [
                    4,
                    9
                ],
                "node": "Case 1: $A$ has 4 black vertices."
            },
            {
                "step_id": 11,
                "edge": "The number of ways to choose all 4 black vertices in A for Case 1 (Step 10) is given by the binomial coefficient \\binom{4}{4}. Calculating this as 1 is trivial but necessary; it confirms there is exactly one configuration where A is entirely black, which aligns with combinatorial principles for selecting all elements from a set.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "There is $\\binom{4}{4}=1$ way to choose 4 black vertices in $A$."
            },
            {
                "step_id": 12,
                "edge": "Since A is entirely black (Step 10) and every edge connects A to B (Step 6), each vertex in B has neighbors exclusively in A. Therefore, all neighbors of any B vertex are black. This deduction follows directly from the bipartite adjacency property and the current case's assumption about A's coloring.",
                "direct_dependent_steps": [
                    6,
                    10
                ],
                "node": "Each vertex in $B$ then has all neighbors colored black."
            },
            {
                "step_id": 13,
                "edge": "Given that all neighbors of each B vertex are black (Step 12), the constraint from Step 8 requires these B vertices to also be black. This is a direct application of the problem's condition: uniform neighbor colors force the vertex to match, eliminating any choice for B's coloring in this case.",
                "direct_dependent_steps": [
                    8,
                    12
                ],
                "node": "The condition forces each vertex in $B$ to be colored black."
            },
            {
                "step_id": 14,
                "edge": "From Step 13, the forced black coloring for all B vertices leaves exactly one valid coloring for set B. This follows because no degrees of freedom remain once the constraint is applied—each vertex's color is uniquely determined by its neighbors' colors.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "There is exactly 1 coloring of $B$ under this forcing."
            },
            {
                "step_id": 15,
                "edge": "Combining the 1 way to color A (Step 11) and the 1 forced coloring for B (Step 14), Case 1 yields 1 × 1 = 1 valid coloring. This multiplication principle applies because the color choices for A and B are independent once constraints are resolved, and both counts are exact for this case.",
                "direct_dependent_steps": [
                    11,
                    14
                ],
                "node": "Therefore case 1 yields $1\\cdot1=1$ valid coloring."
            },
            {
                "step_id": 16,
                "edge": "Expanding the casework from Step 9, we now consider when A has exactly 3 black vertices and 1 white vertex. This case explores intermediate configurations where most of A is uniform but one vertex differs, potentially creating partial forcing conditions in B that require careful analysis of neighbor relationships.",
                "direct_dependent_steps": [
                    9
                ],
                "node": "Case 2: $A$ has 3 black vertices and 1 white vertex."
            },
            {
                "step_id": 17,
                "edge": "The number of ways to choose the single white vertex in A for Case 2 (Step 16) is \\binom{4}{1} = 4. This uses the combination formula to count selections of 1 vertex out of 4, which is straightforward since each choice corresponds to a distinct vertex in A (Step 4).",
                "direct_dependent_steps": [
                    16
                ],
                "node": "There are $\\binom{4}{1}=4$ ways to choose the white vertex in $A$."
            },
            {
                "step_id": 18,
                "edge": "For any choice of white vertex in A (Step 17), the three black vertices in A share a unique common neighbor in B. This arises from the cube's geometry: three vertices differing from a base vertex in one coordinate each meet at the vertex obtained by flipping the coordinate where the white vertex differs. Thus, exactly one B vertex is adjacent to all three black A vertices.",
                "direct_dependent_steps": [
                    17
                ],
                "node": "Under this choice there is exactly one vertex in $B$ adjacent to all 3 black vertices in $A$."
            },
            {
                "step_id": 19,
                "edge": "The B vertex adjacent to all three black A vertices (Step 18) has uniformly black neighbors, so Step 8's condition forces it to be black. This is a direct consequence of the problem's constraint—no alternative color is permissible for this vertex, as it would violate the uniform-neighbor requirement.",
                "direct_dependent_steps": [
                    8,
                    18
                ],
                "node": "That $B$ vertex has all its neighbors black and hence must be colored black by the condition."
            },
            {
                "step_id": 20,
                "edge": "With 4 total vertices in B (Step 5) and one forced to black (Step 19), the remaining 3 vertices in B have no constraints from their A neighbors. This is because each has at least one white neighbor in A (the single white vertex affects only its direct neighbors), so no uniform-neighbor condition applies to them initially.",
                "direct_dependent_steps": [
                    5,
                    19
                ],
                "node": "The remaining 3 vertices of $B$ have no forced color assignments."
            },
            {
                "step_id": 21,
                "edge": "The 3 unconstrained vertices in B (Step 20) each have 2 color choices (black or white), leading to 2^3 = 8 possible colorings. This follows from the multiplication principle for independent choices, as established in Step 7's basic coloring rule.",
                "direct_dependent_steps": [
                    20
                ],
                "node": "The 3 remaining vertices of $B$ have $2^3$ possible colorings."
            },
            {
                "step_id": 22,
                "edge": "Among the 8 colorings from Step 21, the all-black option is invalid. If all three remaining B vertices were black, the white vertex in A (Step 17) would have all neighbors black (since it connects to all B vertices), violating Step 8's requirement that it must then be black—contradicting its white assignment.",
                "direct_dependent_steps": [
                    8,
                    21
                ],
                "node": "The coloring where those 3 vertices are all black is forbidden."
            },
            {
                "step_id": 23,
                "edge": "Excluding the 1 forbidden all-black coloring from Step 22 leaves 8 - 1 = 7 valid colorings for the remaining B vertices. This adjustment ensures no configuration violates the problem's constraint, as verified by the contradiction identified in Step 22.",
                "direct_dependent_steps": [
                    21,
                    22
                ],
                "node": "Hence there are $2^3-1=7$ valid colorings of the remaining $B$ vertices."
            },
            {
                "step_id": 24,
                "edge": "Multiplying the 4 choices for the white vertex in A (Step 17) by the 7 valid B colorings (Step 23) gives 4 × 7 = 28 valid colorings for Case 2. This accounts for all combinations where A has three black vertices while respecting the problem's constraints.",
                "direct_dependent_steps": [
                    17,
                    23
                ],
                "node": "Therefore case 2 yields $4\\cdot7=28$ valid colorings."
            },
            {
                "step_id": 25,
                "edge": "Continuing the casework from Step 9, we analyze when A has exactly 2 black and 2 white vertices. This balanced case is the most complex, as neither color dominates sufficiently to force immediate uniformity in B, requiring careful enumeration of valid B colorings that avoid triggering Step 8's condition.",
                "direct_dependent_steps": [
                    9
                ],
                "node": "Case 3: $A$ has 2 black vertices and 2 white vertices."
            },
            {
                "step_id": 26,
                "edge": "The number of ways to choose 2 black vertices in A for Case 3 (Step 25) is \\binom{4}{2} = 6. This counts all pairwise combinations of vertices in A (Step 4), which is standard combinatorial selection for distributing two identical items across four positions.",
                "direct_dependent_steps": [
                    25
                ],
                "node": "There are $\\binom{4}{2}=6$ ways to choose 2 black vertices in $A$."
            },
            {
                "step_id": 27,
                "edge": "For any selection of two black vertices in A (Step 26), no vertex in B has all neighbors the same color in A. This is because the two black and two white vertices in A are positioned such that each B vertex (which has three A neighbors) sees a mix of colors—verified by the cube's adjacency structure where no B vertex connects exclusively to one color class in this configuration.",
                "direct_dependent_steps": [
                    26
                ],
                "node": "Under this selection no vertex in $B$ has all neighbors of the same color in $A$."
            },
            {
                "step_id": 28,
                "edge": "Since no B vertex has uniformly colored neighbors in A (Step 27), Step 8's condition does not force any specific color for B vertices based solely on A's coloring. This means B colorings are initially unconstrained by A, though later steps will identify indirect constraints from the reverse direction (B affecting A).",
                "direct_dependent_steps": [
                    8,
                    27
                ],
                "node": "Thus no $B$ vertex is forced to a specific color by its neighbors in $A$."
            },
            {
                "step_id": 29,
                "edge": "With no initial constraints on B (Step 28), all 2^4 = 16 colorings of the 4 vertices in B (Step 5) are theoretically possible. This follows from Step 7's basic coloring rule, where each vertex independently chooses black or white without restrictions at this stage.",
                "direct_dependent_steps": [
                    28
                ],
                "node": "The 4 vertices in $B$ have $2^4$ total colorings."
            },
            {
                "step_id": 30,
                "edge": "The all-black coloring of B (Step 29) is invalid because each white vertex in A would then have all neighbors black. By Step 8, these white vertices must become black, contradicting their assignment. Thus, this uniform coloring violates the constraint when propagated back to A.",
                "direct_dependent_steps": [
                    8,
                    29
                ],
                "node": "The coloring where all vertices in $B$ are black is forbidden because each white vertex in $A$ would then have all neighbors black and be forced to black."
            },
            {
                "step_id": 31,
                "edge": "Similarly, the all-white coloring of B (Step 29) is invalid because each black vertex in A would have all neighbors white, forcing them to white by Step 8—again contradicting their black assignment. This symmetry between black and white highlights the constraint's bidirectional nature.",
                "direct_dependent_steps": [
                    8,
                    29
                ],
                "node": "The coloring where all vertices in $B$ are white is forbidden because each black vertex in $A$ would then have all neighbors white and be forced to white."
            },
            {
                "step_id": 32,
                "edge": "Combining Step 30 and Step 31, both monochromatic colorings of B are forbidden, removing 2 options from the total. This explicitly identifies the invalid extremes that would cause contradictions when the constraint is applied to A vertices.",
                "direct_dependent_steps": [
                    30,
                    31
                ],
                "node": "Therefore the 2 all-same-color choices are forbidden."
            },
            {
                "step_id": 33,
                "edge": "Subtracting the 2 forbidden colorings from Step 32 from the 16 total in Step 29 gives 16 - 2 = 14 permissible B colorings. This intermediate count includes all non-uniform colorings but requires further refinement to exclude colorings that indirectly violate constraints.",
                "direct_dependent_steps": [
                    29,
                    32
                ],
                "node": "This leaves $2^4-2=14$ possible colorings of $B$."
            },
            {
                "step_id": 34,
                "edge": "Among B's colorings, there are \\binom{4}{1} = 4 configurations with exactly 3 black and 1 white vertex. This counts the ways to choose which single vertex in B (Step 5) is white, using standard combination logic for distributing one distinct item across four positions.",
                "direct_dependent_steps": [
                    5
                ],
                "node": "There are $\\binom{4}{1}=4$ colorings of $B$ with exactly 3 black vertices and 1 white vertex."
            },
            {
                "step_id": 35,
                "edge": "For each coloring with 3 black B vertices (Step 34), there exists a white vertex in A adjacent to all three black B vertices. Step 8 would then force this white A vertex to black, creating a contradiction. This occurs because the cube's structure ensures that any three B vertices share a common A neighbor when they form a 'face' configuration.",
                "direct_dependent_steps": [
                    8,
                    34
                ],
                "node": "In each such coloring a white vertex in $A$ adjacent to the 3 black vertices in $B$ would have all neighbors black and be forced to black."
            },
            {
                "step_id": 36,
                "edge": "The 4 colorings identified in Step 35 are invalid due to the contradiction described, so they must be excluded from the count. This follows directly from Step 35's deduction that such configurations violate the problem's constraint when analyzed through A's perspective.",
                "direct_dependent_steps": [
                    35
                ],
                "node": "Therefore those 4 colorings are forbidden."
            },
            {
                "step_id": 37,
                "edge": "Adjusting the 14 colorings from Step 33 by removing the 4 invalid ones in Step 36 yields 14 - 4 = 10 valid colorings for B in Case 3. This final count for B accounts for all constraints, ensuring no coloring forces a contradiction in A.",
                "direct_dependent_steps": [
                    33,
                    36
                ],
                "node": "Hence there are $14-4=10$ valid colorings of $B$ in case 3."
            },
            {
                "step_id": 38,
                "edge": "Multiplying the 6 ways to choose black vertices in A (Step 26) by the 10 valid B colorings (Step 37) gives 6 × 10 = 60 valid colorings for Case 3. This comprehensive calculation handles the most nuanced case by systematically eliminating invalid configurations.",
                "direct_dependent_steps": [
                    26,
                    37
                ],
                "node": "Therefore case 3 yields $6\\cdot10=60$ valid colorings."
            },
            {
                "step_id": 39,
                "edge": "Proceeding with the casework from Step 9, we examine when A has exactly 1 black vertex and 3 white vertices. This case mirrors Case 2 (Step 16) but with colors reversed, leveraging the problem's symmetry between black and white to simplify analysis.",
                "direct_dependent_steps": [
                    9
                ],
                "node": "Case 4: $A$ has 1 black vertex and 3 white vertices."
            },
            {
                "step_id": 40,
                "edge": "The number of ways to choose the single black vertex in A for Case 4 (Step 39) is \\binom{4}{1} = 4, identical to Step 17's count for the white vertex in Case 2. This symmetry arises because selecting one black vertex is combinatorially equivalent to selecting one white vertex in the four-vertex set A.",
                "direct_dependent_steps": [
                    39
                ],
                "node": "There are $\\binom{4}{1}=4$ ways to choose the black vertex in $A$."
            },
            {
                "step_id": 41,
                "edge": "Case 4 is symmetric to Case 2 under color swap (black ↔ white), as both involve one vertex of a color and three of the other in A. Since Step 24 calculated 28 valid colorings for Case 2, the same count must apply to Case 4 due to this symmetry—no recalculation is needed because the constraint treats both colors identically.",
                "direct_dependent_steps": [
                    24
                ],
                "node": "This case is symmetric to case 2 by exchanging the roles of black and white."
            },
            {
                "step_id": 42,
                "edge": "Applying the symmetry argument from Step 41 to the 4 vertex choices in Step 40, Case 4 yields 28 valid colorings—matching Case 2's result. This avoids redundant computation by recognizing the problem's color-invariance, which preserves constraint behavior under permutation.",
                "direct_dependent_steps": [
                    40,
                    41
                ],
                "node": "Therefore case 4 yields the same number of valid colorings as case 2, namely 28."
            },
            {
                "step_id": 43,
                "edge": "Completing the casework from Step 9, we consider when A has 0 black vertices (all white). This is the color-swapped counterpart to Case 1 (Step 10), where A was entirely black, and will similarly force uniform coloring in B.",
                "direct_dependent_steps": [
                    9
                ],
                "node": "Case 5: $A$ has 0 black vertices and 4 white vertices."
            },
            {
                "step_id": 44,
                "edge": "The number of ways to choose 0 black vertices in A for Case 5 (Step 43) is \\binom{4}{0} = 1, analogous to Step 11. This confirms there is exactly one configuration where A is entirely white, as expected for selecting no elements from a set.",
                "direct_dependent_steps": [
                    43
                ],
                "node": "There is $\\binom{4}{0}=1$ way to choose 0 black vertices in $A$."
            },
            {
                "step_id": 45,
                "edge": "With A entirely white (Step 43) and edges connecting A to B (Step 6), each B vertex has all neighbors white. This mirrors Step 12's logic but with colors reversed, following directly from the bipartite adjacency structure.",
                "direct_dependent_steps": [
                    6,
                    43
                ],
                "node": "Each vertex in $B$ then has all neighbors colored white."
            },
            {
                "step_id": 46,
                "edge": "Since all neighbors of each B vertex are white (Step 45), Step 8's condition forces these B vertices to be white. This is the color-swapped version of Step 13, where uniform neighbor colors dictate the vertex's required color.",
                "direct_dependent_steps": [
                    8,
                    45
                ],
                "node": "The condition forces each vertex in $B$ to be colored white."
            },
            {
                "step_id": 47,
                "edge": "As in Step 14, the forced white coloring for all B vertices leaves exactly one valid coloring for set B. No alternatives exist once the constraint is applied, eliminating all choice for B's configuration.",
                "direct_dependent_steps": [
                    46
                ],
                "node": "There is exactly 1 coloring of $B$ under this forcing."
            },
            {
                "step_id": 48,
                "edge": "Combining the 1 way to color A (Step 44) and the 1 forced coloring for B (Step 47), Case 5 yields 1 × 1 = 1 valid coloring. This parallels Step 15 but for the all-white scenario, completing the symmetric extreme cases.",
                "direct_dependent_steps": [
                    44,
                    47
                ],
                "node": "Therefore case 5 yields $1\\cdot1=1$ valid coloring."
            },
            {
                "step_id": 49,
                "edge": "Summing the valid colorings from all cases—1 (Step 15), 28 (Step 24), 60 (Step 38), 28 (Step 42), and 1 (Step 48)—gives 1 + 28 + 60 + 28 + 1 = 118. This total accounts for every possible coloring configuration without overlap, as the casework partitions all possibilities based on A's black vertex count, and each case's count was rigorously validated against the problem's constraint.",
                "direct_dependent_steps": [
                    15,
                    24,
                    38,
                    42,
                    48
                ],
                "node": "Summing the contributions from all cases gives $1+28+60+28+1=118$ valid colorings."
            }
        ]
    }
]
