[
    {
        "problem_id": 1872,
        "domain": [
            "Mathematics -> Geometry -> Plane Geometry -> Triangulations"
        ],
        "difficulty": 3.5,
        "problem_text": "Let $A B C D$ be a convex quadrilateral so that all of its sides and diagonals have integer lengths. Given that $\\angle A B C=\\angle A D C=90^{\\circ}, A B=B D$, and $C D=41$, find the length of $B C$.",
        "sample_id": 1,
        "final_answer": "The final answer is \\boxed{580}",
        "steps": [
            {
                "step_id": 1,
                "edge": "The problem statement explicitly specifies that ABCD is a convex quadrilateral, establishing this as a given condition for the entire solution. This convexity ensures the quadrilateral has no reflex angles and lies entirely on one side of each side, which is necessary for later cyclic quadrilateral properties to apply cleanly.",
                "direct_dependent_steps": null,
                "node": "Quadrilateral ABCD is convex."
            },
            {
                "step_id": 2,
                "edge": "This is directly provided in the problem statement: $\\angle ABC = 90^{\\circ}$. This right angle at vertex B will be crucial for applying the Pythagorean theorem in triangle ABC later in the solution.",
                "direct_dependent_steps": null,
                "node": "Angle ABC = 90°."
            },
            {
                "step_id": 3,
                "edge": "This is given in the problem statement: $\\angle ADC = 90^{\\circ}$. This right angle at vertex D allows us to apply the Pythagorean theorem in triangle ADC immediately, which is foundational for deriving relationships between side lengths.",
                "direct_dependent_steps": null,
                "node": "Angle ADC = 90°."
            },
            {
                "step_id": 4,
                "edge": "Adding the given angles from Step 2 ($\\angle ABC = 90^{\\circ}$) and Step 3 ($\\angle ADC = 90^{\\circ}$) yields $90^{\\circ} + 90^{\\circ} = 180^{\\circ}$. This sum of opposite angles is a key observation that will enable us to establish cyclicity of the quadrilateral using a standard geometric theorem.",
                "direct_dependent_steps": [
                    2,
                    3
                ],
                "node": "Angle ABC + angle ADC = 180°."
            },
            {
                "step_id": 5,
                "edge": "This is a fundamental theorem in plane geometry: for any convex quadrilateral, the condition that one pair of opposite angles sums to $180^{\\circ}$ is both necessary and sufficient for the quadrilateral to be cyclic (i.e., inscribable in a circle). This theorem is background knowledge not explicitly stated in the problem but required for the logical progression.",
                "direct_dependent_steps": null,
                "node": "A quadrilateral is cyclic if and only if a pair of opposite angles sum to 180°."
            },
            {
                "step_id": 6,
                "edge": "Combining Step 1 (convexity of ABCD), Step 4 (opposite angles sum to $180^{\\circ}$), and Step 5 (the cyclic quadrilateral theorem), we conclude ABCD must be cyclic. Convexity ensures the theorem applies without ambiguity, and the angle sum satisfies the exact condition required for cyclicity.",
                "direct_dependent_steps": [
                    1,
                    4,
                    5
                ],
                "node": "Therefore quadrilateral ABCD is cyclic."
            },
            {
                "step_id": 7,
                "edge": "Since Step 6 establishes ABCD as cyclic, it has a circumcircle passing through all four vertices. Therefore, $\\angle ADC$, being an angle of the quadrilateral, is an inscribed angle in this circumcircle by definition of cyclic quadrilaterals.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Angle ADC is an inscribed angle in the circumcircle of ABCD."
            },
            {
                "step_id": 8,
                "edge": "This is a standard circle geometry theorem: an inscribed angle measuring $90^{\\circ}$ must intercept an arc of $180^{\\circ}$, meaning the chord it subtends is a diameter of the circle. This principle is background knowledge essential for identifying the diameter from the right angle.",
                "direct_dependent_steps": null,
                "node": "An inscribed angle that measures 90° intercepts a diameter."
            },
            {
                "step_id": 9,
                "edge": "From Step 7, $\\angle ADC$ is an inscribed angle in the circumcircle, and from Step 3 it measures $90^{\\circ}$. Applying Step 8, this implies the chord intercepted by $\\angle ADC$—which is AC—must be a diameter of the circumcircle. This identification of AC as diameter is pivotal for locating the circle's center.",
                "direct_dependent_steps": [
                    7,
                    8
                ],
                "node": "Therefore chord AC is a diameter of the circumcircle."
            },
            {
                "step_id": 10,
                "edge": "Building on Step 9 (AC is a diameter), we define O as the midpoint of AC. This definition is strategic because the midpoint of any diameter is the natural candidate for the circle's center, which we will verify in subsequent steps.",
                "direct_dependent_steps": [
                    9
                ],
                "node": "Let O be the midpoint of AC."
            },
            {
                "step_id": 11,
                "edge": "This is a basic property of circles: by definition, the center of a circle is the midpoint of any diameter. This geometric fact is background knowledge that connects the midpoint of AC to the circumcenter of ABCD.",
                "direct_dependent_steps": null,
                "node": "The midpoint of a diameter is the center of the circle."
            },
            {
                "step_id": 12,
                "edge": "Combining Step 10 (O is midpoint of AC) and Step 11 (midpoint of diameter is center), we confirm O is the circumcenter of ABCD. This establishes O as the fixed reference point for all radial distances in the circumcircle.",
                "direct_dependent_steps": [
                    10,
                    11
                ],
                "node": "Therefore O is the center of the circumcircle of ABCD."
            },
            {
                "step_id": 13,
                "edge": "In triangle ADC, Step 3 gives $\\angle ADC = 90^{\\circ}$, making it a right triangle with hypotenuse AC. The Pythagorean theorem directly applies: $AD^2 + CD^2 = AC^2$. This equation relates three key lengths we will solve for.",
                "direct_dependent_steps": [
                    3
                ],
                "node": "By the Pythagorean theorem, AD^2 + CD^2 = AC^2."
            },
            {
                "step_id": 14,
                "edge": "The problem explicitly states $CD = 41$, providing a concrete integer value for this side length. This given value is essential for converting the Pythagorean equation into a solvable numerical relationship.",
                "direct_dependent_steps": null,
                "node": "It is given that CD = 41."
            },
            {
                "step_id": 15,
                "edge": "Substituting the given $CD = 41$ from Step 14 into the Pythagorean equation from Step 13 yields $AD^2 + 41^2 = AC^2$. This substitution transforms the general relationship into a specific equation involving only AD and AC, both of which are integers per problem constraints.",
                "direct_dependent_steps": [
                    13,
                    14
                ],
                "node": "Substituting CD = 41 gives AD^2 + 41^2 = AC^2."
            },
            {
                "step_id": 16,
                "edge": "Rearranging Step 15's equation by subtracting $AD^2$ from both sides gives $AC^2 - AD^2 = 41^2$. This algebraic manipulation isolates the difference of squares, preparing for factorization—a standard technique for solving Diophantine equations with integer constraints.",
                "direct_dependent_steps": [
                    15
                ],
                "node": "Rearranging yields AC^2 - AD^2 = 41^2."
            },
            {
                "step_id": 17,
                "edge": "Applying the difference of squares factorization to Step 16's expression yields $(AC - AD)(AC + AD) = 41^2$. This factorization is critical because it converts the equation into a product of two integers equal to $1681$, leveraging the problem's integer-length requirement for systematic solution.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "Factoring gives (AC - AD)(AC + AD) = 41^2."
            },
            {
                "step_id": 18,
                "edge": "Given that AC and AD are positive integers (from problem constraints) and 41 is prime, the factor pairs of $41^2 = 1681$ are limited. Since $AC > AD$ (AC is hypotenuse), the only valid pair satisfying $AC - AD < AC + AD$ and both factors positive is $AC - AD = 1$ and $AC + AD = 1681$ (the pair $(41,41)$ would imply $AD=0$, which is impossible for a quadrilateral side).",
                "direct_dependent_steps": [
                    17
                ],
                "node": "Since AC and AD are integers and 41 is prime, AC - AD = 1 and AC + AD = 1681."
            },
            {
                "step_id": 19,
                "edge": "Adding the two equations from Step 18: $(AC - AD) + (AC + AD) = 1 + 1681$ simplifies to $2AC = 1682$, so $AC = 841$. Sanity check: $841$ is an integer, and since $AC$ is a diagonal in a convex quadrilateral with right angles, it must exceed both legs—$841 > 41$ holds true.",
                "direct_dependent_steps": [
                    18
                ],
                "node": "Solving yields AC = 841."
            },
            {
                "step_id": 20,
                "edge": "Subtracting the equations from Step 18: $(AC + AD) - (AC - AD) = 1681 - 1$ gives $2AD = 1680$, so $AD = 840$. Verification: $840$ is a positive integer, and plugging back into Step 15: $840^2 + 41^2 = 705600 + 1681 = 707281 = 841^2$ (since $841^2 = (800+41)^2 = 640000 + 65600 + 1681 = 707281$), confirming correctness.",
                "direct_dependent_steps": [
                    18
                ],
                "node": "Solving yields AD = 840."
            },
            {
                "step_id": 21,
                "edge": "We introduce M as the midpoint of AD to exploit circle symmetry properties. This construction is strategic because perpendicular bisectors of chords pass through the circle's center, which will help relate AD to the circumradius.",
                "direct_dependent_steps": null,
                "node": "Let M be the midpoint of AD."
            },
            {
                "step_id": 22,
                "edge": "By the definition of a midpoint (Step 21), M divides AD into two equal segments, so $AM = AD/2$. This basic geometric property establishes the relationship between the full chord length and its half-segment.",
                "direct_dependent_steps": [
                    21
                ],
                "node": "By definition of midpoint, AM = AD/2."
            },
            {
                "step_id": 23,
                "edge": "Substituting $AD = 840$ from Step 20 into Step 22's equation gives $AM = 840/2 = 420$. This computation provides a concrete length for AM, which will be used in right-triangle calculations involving the circumcenter O.",
                "direct_dependent_steps": [
                    22,
                    20
                ],
                "node": "Substituting AD = 840 gives AM = 420."
            },
            {
                "step_id": 24,
                "edge": "This is a standard circle theorem: the line segment from the center of a circle to the midpoint of a chord is perpendicular to the chord. This property is background knowledge essential for establishing right angles in subsequent triangles.",
                "direct_dependent_steps": null,
                "node": "In a circle, the line from the center to the midpoint of a chord is perpendicular to the chord."
            },
            {
                "step_id": 25,
                "edge": "Combining Step 12 (O is circumcenter), Step 21 (M is midpoint of chord AD), and Step 24 (center-to-midpoint perpendicularity), we conclude $OM \\perp AD$. This perpendicularity creates right angles necessary for applying the Pythagorean theorem in triangle AOM.",
                "direct_dependent_steps": [
                    12,
                    21,
                    24
                ],
                "node": "Since M is the midpoint of chord AD, OM ⟂ AD."
            },
            {
                "step_id": 26,
                "edge": "From Step 25 ($OM \\perp AD$), the angle at M in triangle AOM is $90^{\\circ}$, making it a right triangle. This identification is crucial because it validates the use of the Pythagorean theorem for relating OA, OM, and AM.",
                "direct_dependent_steps": [
                    25
                ],
                "node": "Therefore triangle AOM is right-angled at M."
            },
            {
                "step_id": 27,
                "edge": "Applying the Pythagorean theorem to right triangle AOM (Step 26) gives $OM^2 + AM^2 = OA^2$. This equation will allow us to solve for OM once we know OA and AM, leveraging the circumradius properties.",
                "direct_dependent_steps": [
                    26
                ],
                "node": "By the Pythagorean theorem in triangle AOM, OM^2 + AM^2 = OA^2."
            },
            {
                "step_id": 28,
                "edge": "Since AC is the diameter (Step 9) and O is its midpoint (Step 10), OA is the radius, so $OA = AC/2$. Substituting $AC = 841$ from Step 19 yields $OA = 841/2$. This expresses the radius in terms of the known diameter.",
                "direct_dependent_steps": [
                    10,
                    19
                ],
                "node": "Since OA = AC/2, OA = 841/2."
            },
            {
                "step_id": 29,
                "edge": "Substituting $AM = 420$ from Step 23 and $OA = 841/2$ from Step 28 into Step 27's equation gives $OM^2 + 420^2 = (841/2)^2$. This substitution sets up a solvable equation for OM, incorporating all known values from prior steps.",
                "direct_dependent_steps": [
                    27,
                    23,
                    28
                ],
                "node": "Substituting AM = 420 and OA = 841/2 into OM^2 + AM^2 = OA^2 gives OM^2 + 420^2 = (841/2)^2."
            },
            {
                "step_id": 30,
                "edge": "Solving Step 29's equation: $OM^2 = (841/2)^2 - 420^2 = (841^2 - 840^2)/4$. Using difference of squares, $841^2 - 840^2 = (841-840)(841+840) = 1 \\times 1681 = 1681$, so $OM^2 = 1681/4$ and $OM = 41/2$ (taking positive root as length). Sanity check: $41/2 = 20.5$, and $(20.5)^2 + 420^2 = 420.25 + 176400 = 176820.25 = (420.5)^2 = (841/2)^2$, which holds since $841/2 = 420.5$.",
                "direct_dependent_steps": [
                    29
                ],
                "node": "Solving for OM yields OM = 41/2."
            },
            {
                "step_id": 31,
                "edge": "From Step 25 ($OM \\perp AD$) and Step 21 (M is midpoint of AD), OM is perpendicular to AD at its midpoint, satisfying the definition of a perpendicular bisector. This characterization is vital for applying the equidistant property of points on perpendicular bisectors.",
                "direct_dependent_steps": [
                    25,
                    21
                ],
                "node": "Since OM ⟂ AD at the midpoint, OM is the perpendicular bisector of chord AD."
            },
            {
                "step_id": 32,
                "edge": "This is a fundamental geometry principle: any point lying on the perpendicular bisector of a segment is equidistant from the segment's endpoints. This theorem is background knowledge that will justify why point B (defined next) satisfies $AB = BD$.",
                "direct_dependent_steps": null,
                "node": "Any point on the perpendicular bisector of a segment is equidistant from the segment's endpoints."
            },
            {
                "step_id": 33,
                "edge": "We define B as the second intersection point of line OM with the circumcircle (beyond the obvious first intersection in the opposite direction from M). This strategic choice places B on the perpendicular bisector of AD (line OM), which will ensure $AB = BD$ via the equidistant property.",
                "direct_dependent_steps": null,
                "node": "Let B be the second intersection of line OM with the circumcircle of ABCD."
            },
            {
                "step_id": 34,
                "edge": "Combining Step 31 (OM is perpendicular bisector of AD), Step 32 (equidistant property of perpendicular bisectors), and Step 33 (B lies on line OM), we conclude $BA = BD$. This satisfies the problem's given condition $AB = BD$, confirming our construction of B is valid.",
                "direct_dependent_steps": [
                    31,
                    32,
                    33
                ],
                "node": "Then BA = BD."
            },
            {
                "step_id": 35,
                "edge": "From Step 33 (B is defined on line OM) and Step 34 (B satisfies the equidistant property via the perpendicular bisector), we reiterate that B lies on line OM. This reinforces the geometric alignment necessary for subsequent distance calculations along this line.",
                "direct_dependent_steps": [
                    33,
                    34
                ],
                "node": "B lies on line OM."
            },
            {
                "step_id": 36,
                "edge": "Given Step 33 (B is the second intersection of line OM with the circumcircle) and Step 12 (O is the circumcenter), the line OM extends from O through M to the circle at one point, with B on the opposite side of O from M. Thus, O lies between M and B on the straight line OM, a consequence of the circle's symmetry about O.",
                "direct_dependent_steps": [
                    33,
                    12
                ],
                "node": "Point O lies between M and B on line OM."
            },
            {
                "step_id": 37,
                "edge": "Since Step 36 establishes O is between M and B on line OM, the segment BM is the sum of segments BO and OM. As lengths are positive, $BM = OB + OM$. This additive relationship is essential for computing BM from known radii and distances.",
                "direct_dependent_steps": [
                    36
                ],
                "node": "Therefore BM = OB + OM."
            },
            {
                "step_id": 38,
                "edge": "Substituting $OB = OA = 841/2$ (radii from Step 12 and Step 28), $OM = 41/2$ (from Step 30), and the additive relation from Step 37 gives $BM = 841/2 + 41/2 = 882/2 = 441$. Verification: $441$ is an integer, consistent with problem constraints, and $841/2 + 41/2 = (841 + 41)/2 = 882/2 = 441$ is arithmetically sound.",
                "direct_dependent_steps": [
                    12,
                    28,
                    30,
                    37
                ],
                "node": "Since OB = OA = 841/2 and OM = 41/2, BM = 441."
            },
            {
                "step_id": 39,
                "edge": "From Step 25 ($OM \\perp AD$) and Step 35 (B lies on line OM), it follows that $BM \\perp AD$. Since AM is part of AD, $BM \\perp AM$, making triangle ABM right-angled at M. This right angle enables the Pythagorean theorem for AB.",
                "direct_dependent_steps": [
                    25,
                    35
                ],
                "node": "Since BM ⟂ AM, triangle ABM is right-angled at M."
            },
            {
                "step_id": 40,
                "edge": "Applying the Pythagorean theorem to right triangle ABM (Step 39) gives $AB = \\sqrt{AM^2 + BM^2}$. This formula expresses AB in terms of known lengths AM and BM, which we will compute numerically.",
                "direct_dependent_steps": [
                    39
                ],
                "node": "By the Pythagorean theorem, AB = √(AM^2 + BM^2)."
            },
            {
                "step_id": 41,
                "edge": "Substituting $AM = 420$ (Step 23) and $BM = 441$ (Step 38) into Step 40's formula: $AB = \\sqrt{420^2 + 441^2} = \\sqrt{176400 + 194481} = \\sqrt{370881}$. Calculating: $609^2 = (600+9)^2 = 360000 + 10800 + 81 = 370881$, so $AB = 609$. Sanity check: $609$ is integer and satisfies $609^2 = 370881$.",
                "direct_dependent_steps": [
                    40,
                    23,
                    38
                ],
                "node": "Substituting AM = 420 and BM = 441 gives AB = 609."
            },
            {
                "step_id": 42,
                "edge": "In triangle ABC, Step 2 gives $\\angle ABC = 90^{\\circ}$, making it a right triangle with hypotenuse AC. The Pythagorean theorem applies: $BC^2 + AB^2 = AC^2$. This equation will allow us to solve for BC using known values of AB and AC.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "In triangle ABC with right angle at B, BC^2 + AB^2 = AC^2."
            },
            {
                "step_id": 43,
                "edge": "Substituting $AB = 609$ (Step 41) and $AC = 841$ (Step 19) into Step 42's equation: $BC^2 = AC^2 - AB^2 = 841^2 - 609^2$. Factoring as difference of squares: $(841 - 609)(841 + 609) = 232 \\times 1450 = 336400$. Thus $BC = \\sqrt{336400} = 580$ (since $580^2 = (500+80)^2 = 250000 + 80000 + 6400 = 336400$). Verification: $580$ is integer, and $609^2 + 580^2 = 370881 + 336400 = 707281 = 841^2$, confirming correctness.",
                "direct_dependent_steps": [
                    42,
                    41,
                    19
                ],
                "node": "Substituting AB = 609 and AC = 841 yields BC = 580."
            }
        ]
    }
]
