[
    {
        "problem_id": 1458,
        "domain": [
            "Mathematics -> Applied Mathematics -> Statistics -> Probability -> Counting Methods -> Combinations"
        ],
        "difficulty": 4.0,
        "problem_text": "Let $\\mathcal{H}$ be the unit hypercube of dimension 4 with a vertex at $(x, y, z, w)$ for each choice of $x, y, z, w \\in \\{0,1\\}$. A bug starts at the vertex $(0,0,0,0)$. In how many ways can the bug move to $(1,1,1,1)$ by taking exactly 4 steps along the edges of $\\mathcal{H}$?",
        "sample_id": 1,
        "final_answer": "The final answer is \\boxed{24}.",
        "steps": [
            {
                "step_id": 1,
                "edge": "We recall the standard definition of a unit hypercube of dimension n: its vertices consist of all n-tuples where each coordinate is either 0 or 1. For dimension 4, this explicitly means vertices are represented as (x,y,z,w) with each coordinate independently taking values in {0,1}, which establishes the complete vertex set for the problem.",
                "direct_dependent_steps": null,
                "node": "The hypercube $\\mathcal{H}$ of dimension $4$ has vertices $(x,y,z,w)$ for $x,y,z,w\\in\\{0,1\\}$."
            },
            {
                "step_id": 2,
                "edge": "The problem statement explicitly specifies that the bug begins its journey at the vertex (0,0,0,0), so we take this as the fixed starting position for all possible paths under consideration.",
                "direct_dependent_steps": null,
                "node": "The bug starts at the vertex $(0,0,0,0)$."
            },
            {
                "step_id": 3,
                "edge": "Similarly, the problem directly states that the bug must terminate at the vertex (1,1,1,1), which defines the target endpoint for all valid paths we need to count.",
                "direct_dependent_steps": null,
                "node": "The bug must end at the vertex $(1,1,1,1)$."
            },
            {
                "step_id": 4,
                "edge": "Building on the vertex definition from Step 1, we apply the fundamental adjacency property of hypercubes: two vertices share an edge if and only if their coordinate representations differ in exactly one position. This is intrinsic to the hypercube structure, as each edge corresponds to flipping a single binary coordinate between 0 and 1.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "An edge of $\\mathcal{H}$ connects two vertices that differ in exactly one coordinate."
            },
            {
                "step_id": 5,
                "edge": "From Step 4's edge definition, we deduce that traversing an edge requires changing exactly one coordinate. Since all coordinates are binary (0 or 1), this change must be a flip from 0 to 1 (an increase of +1) or 1 to 0 (a decrease of -1). Thus, every edge move alters precisely one coordinate by ±1, which characterizes all possible moves in the hypercube.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "Therefore, moving along an edge changes exactly one coordinate by $\\pm1$."
            },
            {
                "step_id": 6,
                "edge": "Using the starting vertex (0,0,0,0) from Step 2 and ending vertex (1,1,1,1) from Step 3, we compute the coordinate-wise differences: for x: 1-0=1, y:1-0=1, z:1-0=1, w:1-0=1. Therefore, each coordinate must increase by exactly 1 to transition from start to end, establishing the net change required per dimension.",
                "direct_dependent_steps": [
                    2,
                    3
                ],
                "node": "The difference in each coordinate between $(0,0,0,0)$ and $(1,1,1,1)$ is $1$."
            },
            {
                "step_id": 7,
                "edge": "Based on Step 6's observation that each coordinate requires a net increase of 1, we conclude the bug must perform exactly four coordinate-increase operations (one for each dimension) to reach the target vertex. This follows because each increase operation changes a single coordinate from 0 to 1, and all four coordinates need this transition.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Hence the bug needs a total of $4$ coordinate-increase operations to reach $(1,1,1,1)$."
            },
            {
                "step_id": 8,
                "edge": "The problem explicitly constrains the bug to take exactly 4 steps for the entire journey, which provides the critical path-length restriction we must satisfy in counting valid sequences.",
                "direct_dependent_steps": null,
                "node": "The bug takes exactly $4$ steps."
            },
            {
                "step_id": 9,
                "edge": "Combining Step 5 (each step changes one coordinate by ±1), Step 7 (four net increases required), and Step 8 (exactly four steps), we determine that every step must be a +1 change. If any step decreased a coordinate (e.g., from 1 to 0), we would need an additional increase for that coordinate later, but with only four steps total and four required increases, no decreases are possible without exceeding the step limit or violating the target vertex condition.",
                "direct_dependent_steps": [
                    5,
                    7,
                    8
                ],
                "node": "Therefore, each of the $4$ steps must change a coordinate by $+1$."
            },
            {
                "step_id": 10,
                "edge": "From Step 6 (each coordinate needs exactly one +1 change) and Step 9 (all four steps are +1 changes), we deduce that each increment must affect a distinct coordinate. If any coordinate were incremented twice, it would exceed the target value of 1 (e.g., 0→1→2), which is invalid in the binary hypercube, so all four increments must be distributed across different coordinates.",
                "direct_dependent_steps": [
                    6,
                    9
                ],
                "node": "Each of the $4$ increments must occur in a distinct coordinate."
            },
            {
                "step_id": 11,
                "edge": "Given Step 10's requirement that each increment occurs in a distinct coordinate, the problem reduces to counting the number of sequences where we assign each step to a unique coordinate. This is equivalent to permuting the four coordinates: the first step chooses one of four coordinates to increment, the second step chooses from the remaining three, and so on, yielding 4 factorial (4!) possible orderings.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "The number of ways to order increments in $4$ distinct coordinates equals $4!$."
            },
            {
                "step_id": 12,
                "edge": "Step 11 identifies the count as 4!, so we compute 4! = 4 × 3 × 2 × 1 = 24. As a sanity check, we verify that for four distinct items (here, the x,y,z,w coordinates), the number of permutations is indeed 24 (e.g., 4 choices for the first increment position, 3 for the second, 2 for the third, and 1 for the last: 4×3×2×1=24).",
                "direct_dependent_steps": [
                    11
                ],
                "node": "We have $4! = 24$."
            },
            {
                "step_id": 13,
                "edge": "Step 12 calculates the total number of valid paths as 24. Since the problem asks for the count of ways to move from (0,0,0,0) to (1,1,1,1) in exactly 4 edge steps, and our derivation shows this equals 24, we present this as the final answer in the required boxed format.",
                "direct_dependent_steps": [
                    12
                ],
                "node": "The final answer is \\boxed{24}."
            }
        ]
    }
]
