[
    {
        "problem_id": 58,
        "domain": [
            "Mathematics -> Applied Mathematics -> Math Word Problems"
        ],
        "difficulty": 5.0,
        "problem_text": "Farmer Bill's 1000 animals - ducks, cows, and rabbits - are standing in a circle. In order to feel safe, every duck must either be standing next to at least one cow or between two rabbits. If there are 600 ducks, what is the least number of cows there can be for this to be possible?",
        "sample_id": 1,
        "final_answer": "$\\boxed{201}$",
        "steps": [
            {
                "step_id": 1,
                "edge": "We establish the foundational context: all animals stand in a circular arrangement. This circular constraint is critical because adjacency wraps around, meaning the first and last animals are neighbors, which affects how we count valid configurations for the ducks.",
                "direct_dependent_steps": null,
                "node": "Farmer Bill has 1000 animals standing in a circle."
            },
            {
                "step_id": 2,
                "edge": "We identify the three distinct animal types present—ducks, cows, and rabbits—as given in the problem statement. This categorization allows us to define variables and constraints specific to each type in subsequent steps.",
                "direct_dependent_steps": null,
                "node": "The animals consist of ducks, cows, and rabbits."
            },
            {
                "step_id": 3,
                "edge": "Building on Step 2's animal classification, we assign standard algebraic variables: $d$ for ducks, $c$ for cows, $r$ for rabbits. This formalizes the problem into a mathematical framework where we can express relationships and constraints quantitatively.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "Let $d$ be the number of ducks, $c$ be the number of cows, and $r$ be the number of rabbits."
            },
            {
                "step_id": 4,
                "edge": "Using Step 1's total animal count (1000) and Step 3's variable definitions, we write the conservation equation $d + c + r = 1000$. This equation captures the invariant that every animal belongs to exactly one category, forming the basis for all numerical substitutions later.",
                "direct_dependent_steps": [
                    1,
                    3
                ],
                "node": "We have the equation $d + c + r = 1000$."
            },
            {
                "step_id": 5,
                "edge": "We incorporate the problem's specific condition $d = 600$ (600 ducks) directly into Step 3's variable framework. This fixed value anchors our system of equations, reducing the degrees of freedom for solving the remaining variables.",
                "direct_dependent_steps": [
                    3
                ],
                "node": "The problem states that $d = 600$."
            },
            {
                "step_id": 6,
                "edge": "Substituting Step 5's $d = 600$ into Step 4's total equation yields $600 + c + r = 1000$. This substitution is a standard algebraic operation that isolates the unknowns $c$ and $r$, preparing us to express their relationship explicitly.",
                "direct_dependent_steps": [
                    4,
                    5
                ],
                "node": "Substituting $d = 600$ into the total gives $600 + c + r = 1000$."
            },
            {
                "step_id": 7,
                "edge": "Rearranging Step 6's equation by subtracting 600 from both sides gives $c + r = 400$. This simplified form clearly shows the trade-off between cows and rabbits: every additional cow requires one fewer rabbit to maintain the total non-duck count.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Rearranging this equation yields $c + r = 400$."
            },
            {
                "step_id": 8,
                "edge": "We state the core safety constraint for ducks as given in the problem: each duck must have either a cow as a neighbor or rabbits on both sides. This condition defines the logical structure we must satisfy and drives all subsequent combinatorial reasoning.",
                "direct_dependent_steps": null,
                "node": "Every duck must either be adjacent to at least one cow or be flanked by two rabbits."
            },
            {
                "step_id": 9,
                "edge": "To operationalize Step 8's constraint, we define 'rabbit-flanked' as a duck with rabbits on both adjacent positions. This precise definition allows us to categorize ducks based on their immediate neighborhood, which is essential for counting valid configurations.",
                "direct_dependent_steps": null,
                "node": "Define a duck as rabbit-flanked if it has rabbits on both adjacent sides."
            },
            {
                "step_id": 10,
                "edge": "Complementing Step 9, we define 'cow-adjacent' as a duck with at least one neighboring cow. This second category captures the alternative safety condition from Step 8, ensuring we cover all valid duck placements without overlap or omission.",
                "direct_dependent_steps": null,
                "node": "Define a duck as cow-adjacent if it has at least one adjacent cow."
            },
            {
                "step_id": 11,
                "edge": "Combining Step 8's requirement with Steps 9 and 10's definitions, we assert that every duck must fall into exactly one of these two mutually exclusive categories. This dichotomy is fundamental—it partitions the 600 ducks into subsets we can bound mathematically.",
                "direct_dependent_steps": [
                    8,
                    9,
                    10
                ],
                "node": "Each duck must be either rabbit-flanked or cow-adjacent."
            },
            {
                "step_id": 12,
                "edge": "Following Step 9's definition, we introduce $x$ as the count of rabbit-flanked ducks. This variable will help us quantify how many ducks satisfy the 'between two rabbits' condition, enabling us to relate duck placements to rabbit positions.",
                "direct_dependent_steps": [
                    9
                ],
                "node": "Let $x$ be the number of rabbit-flanked ducks."
            },
            {
                "step_id": 13,
                "edge": "Analogous to Step 12, we define $y$ using Step 10's concept to represent cow-adjacent ducks. Tracking this count separately allows us to analyze how cows support duck safety through adjacency.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "Let $y$ be the number of cow-adjacent ducks."
            },
            {
                "step_id": 14,
                "edge": "Using Step 5's fixed duck count ($d=600$), Step 11's partition requirement, and Steps 12-13's variables, we write $x + y = 600$. This equation enforces that all ducks are accounted for in one of the two valid categories, creating a key constraint for our optimization.",
                "direct_dependent_steps": [
                    5,
                    11,
                    12,
                    13
                ],
                "node": "Then we have the equation $x + y = 600$."
            },
            {
                "step_id": 15,
                "edge": "We initiate a bounding argument for $x$ (rabbit-flanked ducks) by focusing on the structural limitations imposed by the rabbit count $r$. This strategic move aims to find the maximum possible $x$ given $r$, which will later help minimize cows.",
                "direct_dependent_steps": null,
                "node": "We now derive an upper bound for $x$ in terms of $r$."
            },
            {
                "step_id": 16,
                "edge": "Applying circular arrangement principles from Step 1, we note that $r$ rabbits create exactly $r$ gaps between consecutive rabbits (since it's a circle, no endpoints exist). This gap count is a standard combinatorial result for circular sequences.",
                "direct_dependent_steps": [
                    3
                ],
                "node": "In a circle with $r$ rabbits, there are $r$ gaps between consecutive rabbits."
            },
            {
                "step_id": 17,
                "edge": "Per Step 9's definition, each rabbit-flanked duck must occupy one rabbit gap (i.e., sit between two rabbits). Step 16 confirms there are exactly $r$ such gaps, establishing that $x$ cannot exceed the number of available gaps.",
                "direct_dependent_steps": [
                    9,
                    16
                ],
                "node": "Each rabbit-flanked duck occupies exactly one of these gaps."
            },
            {
                "step_id": 18,
                "edge": "Since Step 16's $r$ gaps are separated by rabbits, each gap can hold at most one rabbit-flanked duck (as two ducks would require three rabbits to flank both, violating the gap's definition). This prevents multiple ducks from sharing a single gap.",
                "direct_dependent_steps": [
                    9,
                    16
                ],
                "node": "At most one rabbit-flanked duck can occupy a given gap."
            },
            {
                "step_id": 19,
                "edge": "Combining Step 12's definition of $x$, Step 15's bounding goal, and Steps 16-18's gap analysis, we conclude $x \\le r$. This inequality is the first critical bound, linking rabbit count to valid duck placements.",
                "direct_dependent_steps": [
                    12,
                    15,
                    16,
                    17,
                    18
                ],
                "node": "Therefore $x \\le r$."
            },
            {
                "step_id": 20,
                "edge": "Exploring the equality case $x = r$ from Step 19, we observe that Step 12's $x$ rabbit-flanked ducks and Step 16's $r$ rabbits would alternate perfectly (R-D-R-D-...), consuming all $2r$ positions in the circle for these animals alone.",
                "direct_dependent_steps": [
                    12,
                    16,
                    17,
                    18
                ],
                "node": "If $x = r$, then the $r$ rabbits and $x$ rabbit-flanked ducks would alternate around the entire circle."
            },
            {
                "step_id": 21,
                "edge": "Step 20's alternating pattern would use exactly $2r$ positions, leaving no adjacency edges for other animals. But since cows and additional ducks must occupy the remaining $1000 - 2r$ positions, this configuration is invalid—it isolates the alternating block from the rest of the circle.",
                "direct_dependent_steps": [
                    20
                ],
                "node": "Alternation around the entire circle would leave no adjacency edges for the remaining animals."
            },
            {
                "step_id": 22,
                "edge": "Using Step 1's total (1000 animals), Step 7's $c + r = 400$ (so $r \\le 400$), and Steps 20-21's invalidity argument, we see $2r \\le 800 < 1000$. Thus $x = r$ forces an impossible isolated block, proving equality cannot hold in a valid arrangement.",
                "direct_dependent_steps": [
                    1,
                    7,
                    20,
                    21
                ],
                "node": "Since there are 1000 animals and $2r < 1000$ for $r \\le 400$, we cannot have $x = r$."
            },
            {
                "step_id": 23,
                "edge": "From Step 19's $x \\le r$ and Step 22's exclusion of $x = r$, we strengthen the bound to $x \\le r - 1$. This adjustment accounts for the circular arrangement's requirement to integrate all animal types without isolated segments.",
                "direct_dependent_steps": [
                    19,
                    22
                ],
                "node": "Therefore $x \\le r - 1$."
            },
            {
                "step_id": 24,
                "edge": "We now shift focus to bounding $y$ (cow-adjacent ducks), mirroring Step 15's approach but for cows. This parallel analysis will let us combine both bounds to constrain $c$.",
                "direct_dependent_steps": null,
                "node": "We now derive an upper bound for $y$ in terms of $c$."
            },
            {
                "step_id": 25,
                "edge": "In Step 1's circular setup, each cow has exactly two adjacent positions (one on each side), a basic property of circular arrangements where every element has two neighbors.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Each cow has two adjacent positions in the circle."
            },
            {
                "step_id": 26,
                "edge": "Per Step 10, a cow-adjacent duck occupies one of these adjacent positions from Step 25. Thus, each cow can 'support' up to two such ducks—one on each side.",
                "direct_dependent_steps": [
                    10,
                    25
                ],
                "node": "A cow-adjacent duck occupies one of these adjacent positions."
            },
            {
                "step_id": 27,
                "edge": "Since Step 25's adjacent positions are distinct for each cow (no position is shared between cows in a valid arrangement), at most one duck can occupy any single adjacent spot, preventing double-counting.",
                "direct_dependent_steps": [
                    25
                ],
                "node": "At most one cow-adjacent duck can occupy a given position."
            },
            {
                "step_id": 28,
                "edge": "Combining Step 13's $y$, Step 24's goal, and Steps 25-27's adjacency analysis, we derive $y \\le 2c$. This bound reflects that $c$ cows provide at most $2c$ duck-adjacent spots.",
                "direct_dependent_steps": [
                    13,
                    24,
                    25,
                    26,
                    27
                ],
                "node": "Therefore $y \\le 2c$."
            },
            {
                "step_id": 29,
                "edge": "We merge Step 14's $x + y = 600$ with Steps 23 and 28's bounds ($x \\le r - 1$, $y \\le 2c$). Substituting the upper bounds gives $600 \\le (r - 1) + 2c$, which relates all key variables through the tightest possible constraints.",
                "direct_dependent_steps": [
                    14,
                    23,
                    28
                ],
                "node": "Combining $x + y = 600$ with $x \\le r - 1$ and $y \\le 2c$ gives $600 \\le (r - 1) + 2c$."
            },
            {
                "step_id": 30,
                "edge": "To eliminate $r$, we use Step 7's $r + c = 400$ (so $r = 400 - c$) and substitute into Step 29's inequality. This reduction focuses the problem solely on minimizing $c$.",
                "direct_dependent_steps": [
                    7,
                    29
                ],
                "node": "Using $r + c = 400$, we substitute $r = 400 - c$ into this inequality."
            },
            {
                "step_id": 31,
                "edge": "Performing Step 30's substitution: $r - 1$ becomes $(400 - c) - 1 = 399 - c$, so Step 29's inequality transforms to $600 \\le (399 - c) + 2c$. This algebraic replacement is exact and preserves the inequality direction.",
                "direct_dependent_steps": [
                    30
                ],
                "node": "Substituting yields $600 \\le (400 - c - 1) + 2c$."
            },
            {
                "step_id": 32,
                "edge": "Simplifying Step 31's right-hand side: $(399 - c) + 2c = 399 + c$. Thus $600 \\le 399 + c$, a straightforward consolidation of like terms that isolates $c$.",
                "direct_dependent_steps": [
                    31
                ],
                "node": "Simplifying gives $600 \\le 399 + c$."
            },
            {
                "step_id": 33,
                "edge": "Rearranging Step 32's $600 \\le 399 + c$ by subtracting 399 from both sides yields $c \\ge 201$. This arithmetic is verified by $600 - 399 = 201$, confirming the minimal cow count required by the constraints.",
                "direct_dependent_steps": [
                    32
                ],
                "node": "Rearranging this inequality yields $c \\ge 201$."
            },
            {
                "step_id": 34,
                "edge": "Step 33's inequality $c \\ge 201$ proves that 201 is the theoretical minimum number of cows needed. However, we must still demonstrate that an arrangement achieving $c = 201$ exists, as lower bounds alone don't guarantee feasibility.",
                "direct_dependent_steps": [
                    33
                ],
                "node": "Thus any valid arrangement must have at least 201 cows."
            },
            {
                "step_id": 35,
                "edge": "To confirm feasibility, we explicitly construct an arrangement with exactly 201 cows. This constructive approach verifies that the lower bound from Step 34 is achievable, closing the gap between necessity and possibility.",
                "direct_dependent_steps": null,
                "node": "We construct an example arrangement for which $c = 201$."
            },
            {
                "step_id": 36,
                "edge": "Using Step 7's $c + r = 400$ and Step 35's $c = 201$, we compute $r = 400 - 201 = 199$. A quick check: $201 + 199 = 400$, which matches the non-duck total, ensuring consistency.",
                "direct_dependent_steps": [
                    7,
                    35
                ],
                "node": "From $c + r = 400$ and $c = 201$ we get $r = 400 - 201 = 199$."
            },
            {
                "step_id": 37,
                "edge": "We place the 199 rabbits from Step 36 into the circle. This initial placement sets the stage for positioning rabbit-flanked ducks in the subsequent alternating pattern.",
                "direct_dependent_steps": [
                    36
                ],
                "node": "Include $199$ rabbits in the circle."
            },
            {
                "step_id": 38,
                "edge": "We allocate 198 ducks to a dedicated 'first block'—a strategic choice to create rabbit-flanked ducks. The number 198 is selected to match the rabbit count minus one, enabling a near-alternating pattern.",
                "direct_dependent_steps": null,
                "node": "Include $198$ ducks in a first block."
            },
            {
                "step_id": 39,
                "edge": "Arranging Step 37's 199 rabbits and Step 38's 198 ducks alternately (R-D-R-D-...-R) uses all rabbits and leaves one rabbit at each end. Starting and ending with rabbits ensures every duck in this block has rabbits on both sides.",
                "direct_dependent_steps": [
                    37,
                    38
                ],
                "node": "Arrange these $199$ rabbits and $198$ first-block ducks alternately, starting and ending with a rabbit."
            },
            {
                "step_id": 40,
                "edge": "In Step 39's alternating sequence, each of the 198 first-block ducks sits between two rabbits by construction. This satisfies the rabbit-flanked condition (Step 9) for these ducks, as verified by the pattern's symmetry.",
                "direct_dependent_steps": [
                    39
                ],
                "node": "Each of these $198$ first-block ducks is between two rabbits."
            },
            {
                "step_id": 41,
                "edge": "We introduce the 201 cows from Step 35 into the circle. These will support the remaining ducks through adjacency, complementing the rabbit-flanked block.",
                "direct_dependent_steps": [
                    35
                ],
                "node": "Include $201$ cows in the circle."
            },
            {
                "step_id": 42,
                "edge": "The remaining ducks are $600 - 198 = 402$ (from Step 5's total and Step 38's allocation). We group these into a 'second block' to be arranged with cows in a repeating pattern that ensures cow adjacency.",
                "direct_dependent_steps": [
                    5,
                    38
                ],
                "node": "Include $402$ ducks in a second block."
            },
            {
                "step_id": 43,
                "edge": "We arrange Step 41's 201 cows and Step 42's 402 ducks in the repeating unit D-C-D-D. Each unit (4 animals) uses 1 cow and 3 ducks, so 201 units cover all animals: $201 \\times 1 = 201$ cows and $201 \\times 2 = 402$ ducks (since D-C-D-D has three Ds but the last D overlaps with the next unit's first D in the circle).",
                "direct_dependent_steps": [
                    41,
                    42
                ],
                "node": "Arrange these $201$ cows and $402$ second-block ducks in repeating pattern $D C D D$."
            },
            {
                "step_id": 44,
                "edge": "In Step 43's D-C-D-D pattern, every duck is adjacent to at least one cow: the first D neighbors C, the second D neighbors C and the third D, and the third D neighbors the second D and C (from the next unit). Thus all 402 second-block ducks satisfy Step 10's cow-adjacent condition.",
                "direct_dependent_steps": [
                    43
                ],
                "node": "Each of these $402$ second-block ducks is adjacent to at least one cow."
            },
            {
                "step_id": 45,
                "edge": "Connecting Step 39's rabbit-ending block (R) to Step 43's cow-starting block (D) forms a full circle. The transition R-D places a rabbit next to a cow-adjacent duck, which is valid since the duck only requires one cow neighbor (which it has from the D-C pair).",
                "direct_dependent_steps": [
                    39,
                    43
                ],
                "node": "Connect the end of the first block to the start of the second block to form the full circle."
            },
            {
                "step_id": 46,
                "edge": "Summing Step 37's 199 rabbits and Step 41's 201 cows gives $199 + 201 = 400$, matching Step 7's requirement. This confirms the non-duck count is correct.",
                "direct_dependent_steps": [
                    37,
                    41
                ],
                "node": "The total number of rabbits and cows in this arrangement is $199 + 201 = 400$."
            },
            {
                "step_id": 47,
                "edge": "Adding Step 38's 198 first-block ducks and Step 42's 402 second-block ducks yields $198 + 402 = 600$, consistent with Step 5's duck count. Sanity check: $198 + 402 = 600$ holds numerically.",
                "direct_dependent_steps": [
                    38,
                    42
                ],
                "node": "The total number of ducks in this arrangement is $198 + 402 = 600$."
            },
            {
                "step_id": 48,
                "edge": "Combining Step 46's 400 non-ducks and Step 47's 600 ducks gives $400 + 600 = 1000$ animals, satisfying Step 1's total. The circular arrangement is thus complete and numerically valid.",
                "direct_dependent_steps": [
                    46,
                    47
                ],
                "node": "Therefore the circle contains $400 + 600 = 1000$ animals."
            },
            {
                "step_id": 49,
                "edge": "Step 40 ensures all first-block ducks are rabbit-flanked, Step 44 ensures all second-block ducks are cow-adjacent, and Step 45's connection preserves both conditions at the join point. Thus every duck meets Step 8's safety requirement, validating the $c = 201$ arrangement.",
                "direct_dependent_steps": [
                    40,
                    44,
                    45
                ],
                "node": "Every duck in the full circle is either rabbit-flanked or cow-adjacent."
            },
            {
                "step_id": 50,
                "edge": "Step 34 proves $c \\ge 201$ is necessary, while Steps 35-49 construct a valid arrangement with $c = 201$. Together they confirm 201 is the minimal possible cow count, justifying the boxed answer.",
                "direct_dependent_steps": [
                    34,
                    48,
                    49
                ],
                "node": "The final answer is $\\boxed{201}$."
            }
        ]
    }
]
