[
    {
        "problem_id": 2449,
        "domain": [
            "Mathematics -> Geometry -> Plane Geometry -> Polygons"
        ],
        "difficulty": 3.5,
        "problem_text": "Let $A B C$ be an acute triangle with orthocenter $H$. Let $D, E$ be the feet of the $A, B$-altitudes respectively. Given that $A H=20$ and $H D=15$ and $B E=56$, find the length of $B H$.",
        "sample_id": 1,
        "final_answer": "The final answer is \\boxed{50}",
        "steps": [
            {
                "step_id": 1,
                "edge": "This step establishes the foundational setup of the problem. As given in the problem statement, triangle ABC is acute, meaning all interior angles are less than 90 degrees, and H is defined as the orthocenter—the point where all three altitudes intersect. In acute triangles, the orthocenter lies strictly inside the triangle, which will be critical for later geometric reasoning about segment positions.",
                "direct_dependent_steps": null,
                "node": "In acute triangle ABC, H is the orthocenter."
            },
            {
                "step_id": 2,
                "edge": "This defines point D as the foot of the altitude from vertex A to side BC, which is explicitly stated in the problem. By definition, AD is perpendicular to BC, creating a right angle at D. This construction is essential for identifying key segments like AH and HD later in the solution.",
                "direct_dependent_steps": null,
                "node": "Point D is the foot of the A-altitude from A to BC."
            },
            {
                "step_id": 3,
                "edge": "Similarly, this step defines point E as the foot of the altitude from vertex B to side AC, as specified in the problem. This ensures BE is perpendicular to AC, forming another right angle at E. Together with Step 2, this sets up the two altitudes whose intersection properties will be analyzed.",
                "direct_dependent_steps": null,
                "node": "Point E is the foot of the B-altitude from B to AC."
            },
            {
                "step_id": 4,
                "edge": "The length AH = 20 is provided directly in the problem statement. This segment represents the portion of the A-altitude from vertex A to the orthocenter H. This given value will later be used in conjunction with other segment lengths to form equations.",
                "direct_dependent_steps": null,
                "node": "The length of AH is 20."
            },
            {
                "step_id": 5,
                "edge": "The length HD = 15 is given in the problem. This is the segment of the A-altitude from orthocenter H down to foot D on BC. Combined with Step 4, it implies the full A-altitude length AD = AH + HD = 35, though this sum is not yet needed. This value will be crucial for the Power of a Point application.",
                "direct_dependent_steps": null,
                "node": "The length of HD is 15."
            },
            {
                "step_id": 6,
                "edge": "The problem provides BE = 56, which is the full length of the B-altitude from vertex B to foot E on AC. This given value will be used to express segments involving BH and HE, as H lies on BE in acute triangles (verified in later steps).",
                "direct_dependent_steps": null,
                "node": "The length of BE is 56."
            },
            {
                "step_id": 7,
                "edge": "To facilitate algebraic manipulation, we introduce x as the unknown length BH. This variable substitution is a standard problem-solving technique to convert geometric relationships into solvable equations. The goal of the problem is to determine this specific value x.",
                "direct_dependent_steps": null,
                "node": "We let x denote the length of BH."
            },
            {
                "step_id": 8,
                "edge": "Building on Steps 2 and 3, where D and E are defined as feet of altitudes, we recognize that ∠ADB and ∠AEB are both right angles (90°). By the converse of Thales' theorem, any two points subtending a right angle with respect to a segment lie on a circle with that segment as diameter. Here, AB serves as the diameter, placing A, B, D, and E concyclic. Thus, quadrilateral ABDE is cyclic, a key geometric property enabling the Power of a Point theorem application.",
                "direct_dependent_steps": [
                    2,
                    3
                ],
                "node": "Points A, B, D, and E lie on a common circle (i.e., quadrilateral ABDE is cyclic)."
            },
            {
                "step_id": 9,
                "edge": "Since triangle ABC is acute (Step 1) and E is the foot of the B-altitude (Step 3), the orthocenter H must lie strictly between B and E on segment BE. This follows from the definition of orthocenters in acute triangles: all altitudes are internal, so their intersection H cannot coincide with or lie outside the segment endpoints.",
                "direct_dependent_steps": [
                    1,
                    3
                ],
                "node": "The orthocenter H lies on the segment BE between B and E."
            },
            {
                "step_id": 10,
                "edge": "Given that H lies on BE between B and E (Step 9), the entire segment BE decomposes into BH and HE. Using the variable x defined for BH in Step 7, we express HE as the difference BE - BH. This linear relationship is fundamental for translating geometric positions into algebraic expressions.",
                "direct_dependent_steps": [
                    7,
                    9
                ],
                "node": "The length HE equals BE minus BH."
            },
            {
                "step_id": 11,
                "edge": "Substituting the known value BE = 56 from Step 6 and the variable x = BH from Step 7 into the relationship HE = BE - BH (Step 10) yields HE = 56 - x. This substitution converts the geometric decomposition into a concrete algebraic expression ready for use in equations.",
                "direct_dependent_steps": [
                    6,
                    7,
                    10
                ],
                "node": "Substituting lengths gives HE = 56 - x."
            },
            {
                "step_id": 12,
                "edge": "Applying the Power of a Point theorem to point H with respect to the circumcircle of cyclic quadrilateral ABDE (established in Step 8), we note that chords AD and BE intersect at H inside the circle. The theorem states that for intersecting chords, the products of the segment lengths are equal: HB · HE = HD · HA. This equality leverages the cyclic property from Step 8 and the orthocenter's position on BE from Step 9 to create a solvable equation.",
                "direct_dependent_steps": [
                    8,
                    9
                ],
                "node": "By the Power of a Point theorem at H applied to the circumcircle of ABDE, we have HB·HE = HD·HA."
            },
            {
                "step_id": 13,
                "edge": "We substitute all known and expressed lengths into the Power of a Point equation from Step 12. Specifically, HB = x (Step 7), HE = 56 - x (Step 11), HD = 15 (Step 5), and HA = 20 (Step 4). This yields the equation x(56 - x) = 15 · 20, directly connecting the geometric constraints to an algebraic relationship involving x.",
                "direct_dependent_steps": [
                    4,
                    5,
                    7,
                    11,
                    12
                ],
                "node": "Substituting lengths into the power of a point equation gives x(56 - x) = 15·20."
            },
            {
                "step_id": 14,
                "edge": "Evaluating the right-hand side of the equation from Step 13, 15 · 20 is computed as 300. This simple multiplication is verified by noting 15 · 20 = 300, a basic arithmetic fact with no ambiguity, ensuring the equation remains equivalent after substitution.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "The product 15·20 equals 300."
            },
            {
                "step_id": 15,
                "edge": "Replacing 15 · 20 with its computed value 300 (Step 14) in the equation from Step 13 gives x(56 - x) = 300. This simplification maintains the equation's integrity while preparing it for algebraic expansion and solution.",
                "direct_dependent_steps": [
                    13,
                    14
                ],
                "node": "Therefore x(56 - x) = 300."
            },
            {
                "step_id": 16,
                "edge": "Expanding the left-hand side of the equation x(56 - x) = 300 (Step 15) using the distributive property yields 56x - x² = 300. This step rearranges the product into a standard polynomial form, isolating terms for subsequent quadratic manipulation.",
                "direct_dependent_steps": [
                    15
                ],
                "node": "Expanding the left side of the equation yields 56x - x^2 = 300."
            },
            {
                "step_id": 17,
                "edge": "Rearranging 56x - x² = 300 (Step 16) into standard quadratic form involves moving all terms to one side. Subtracting 56x and adding x² to both sides results in x² - 56x + 300 = 0. This format is necessary for applying the quadratic formula in later steps.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "Rearranging terms yields the quadratic equation x^2 - 56x + 300 = 0."
            },
            {
                "step_id": 18,
                "edge": "For the quadratic equation x² - 56x + 300 = 0 (Step 17), the discriminant D = b² - 4ac is calculated with a = 1, b = -56, and c = 300. Thus, D = (-56)² - 4 · 1 · 300. The discriminant determines the nature and number of real solutions, a prerequisite for solving the equation.",
                "direct_dependent_steps": [
                    17
                ],
                "node": "The discriminant of the quadratic equation is 56^2 - 4·1·300."
            },
            {
                "step_id": 19,
                "edge": "Computing the discriminant expression from Step 18: 56² = 3136 (verified by 50² = 2500, 6² = 36, and 2 · 50 · 6 = 600, so 2500 + 600 + 36 = 3136) and 4 · 300 = 1200. Thus, 3136 - 1200 = 1936. This intermediate result is critical for finding the square root in the next step.",
                "direct_dependent_steps": [
                    18
                ],
                "node": "We compute 56^2 - 1200 to obtain 1936."
            },
            {
                "step_id": 20,
                "edge": "Taking the square root of the discriminant 1936 (Step 19) yields 44, since 44 · 44 = 1936 (40² = 1600, 4² = 16, and 2 · 40 · 4 = 320, so 1600 + 320 + 16 = 1936). This positive root is used in the quadratic formula, as lengths must be positive.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "The square root of the discriminant is 44."
            },
            {
                "step_id": 21,
                "edge": "Applying the quadratic formula to x² - 56x + 300 = 0 (Step 17) with discriminant root 44 (Step 20), the solutions are x = [56 ± 44]/2. This follows directly from the formula x = [-b ± √D]/(2a), where b = -56 implies -b = 56, and a = 1 simplifies the denominator.",
                "direct_dependent_steps": [
                    17,
                    20
                ],
                "node": "The quadratic formula gives x = (56 ± 44) / 2."
            },
            {
                "step_id": 22,
                "edge": "Evaluating the two cases from Step 21: (56 + 44)/2 = 100/2 = 50 and (56 - 44)/2 = 12/2 = 6. Both values satisfy the quadratic equation algebraically, but geometric constraints will determine which is valid for the acute triangle configuration.",
                "direct_dependent_steps": [
                    21
                ],
                "node": "Thus the solutions are x = 50 or x = 6."
            },
            {
                "step_id": 23,
                "edge": "Given HD = 15 (Step 5) and x = BH (Step 7), the acute triangle's geometry requires BH > HD. This is because in acute triangles, the orthocenter's position relative to the altitudes ensures that segments from vertices to H (like BH) exceed corresponding segments from H to feet on other altitudes (like HD). Thus, x must be greater than 15 to maintain the triangle's acuteness.",
                "direct_dependent_steps": [
                    5,
                    7
                ],
                "node": "We require x > 15."
            },
            {
                "step_id": 24,
                "edge": "Comparing the solutions x = 50 and x = 6 (Step 22) against the constraint x > 15 (Step 23), we observe that 6 < 15 violates the geometric requirement. This invalidates x = 6 as a physically meaningful solution in the context of the acute triangle.",
                "direct_dependent_steps": [
                    22,
                    23
                ],
                "node": "The solution x = 6 does not satisfy x > 15."
            },
            {
                "step_id": 25,
                "edge": "Since x = 6 fails to satisfy the geometric constraint from Step 23 (as confirmed in Step 24), it is discarded. This leaves x = 50 as the only valid solution for BH, consistent with all given conditions and the acute triangle configuration.",
                "direct_dependent_steps": [
                    24
                ],
                "node": "We discard the solution x = 6."
            }
        ]
    }
]
