unicode

Finished
55
66export class Triangle {
77 /**
8 * @param {...number} sides
8 * Creates a Triangle instance with the given side lengths.
9 * @param {...number} sides - The lengths of the three sides of the triangle.
910 */
1011 constructor(...sides) {
11 throw new Error('Remove this line and implement the function');
12 // Edge Case: Ensure exactly three sides are provided
13 if (sides.length !== 3) {
14 throw new Error('A triangle must have exactly three sides');
15 }
16
17 // Edge Case: Ensure all sides are numbers
18 if (sides.some(side => typeof side !== 'number')) {
19 throw new Error('All sides must be numbers');
20 }
21
22 this.sides = sides;
1223 }
1324
1425 /**
15 * @returns {boolean}
26 * Checks if the triangle is equilateral (all sides equal).
27 * @returns {boolean} True if the triangle is equilateral, false otherwise.
28 * Handled Edge Cases: Invalid triangle (sides <= 0, violates triangle inequality), all sides equal
1629 */
1730 get isEquilateral() {
18 throw new Error('Remove this line and implement the function');
31 const [a, b, c] = this.sides;
32
33 // Edge Case: Check if it's a valid triangle
34 if (!this._isValidTriangle()) {
35 return false;
36 }
37
38 // Edge Case: All sides must be equal for an equilateral triangle
39 return a === b && b === c;
1940 }
2041
2142 /**
22 * @returns {boolean}
43 * Checks if the triangle is isosceles (at least two sides equal).
44 * @returns {boolean} True if the triangle is isosceles, false otherwise.
45 * Handled Edge Cases: Invalid triangle (sides <= 0, violates triangle inequality), at least two sides equal
2346 */
2447 get isIsosceles() {
25 throw new Error('Remove this line and implement the function');
48 const [a, b, c] = this.sides;
49
50 // Edge Case: Check if it's a valid triangle
51 if (!this._isValidTriangle()) {
52 return false;
53 }
54
55 // Edge Case: At least two sides must be equal for an isosceles triangle
56 return a === b || b === c || a === c;
2657 }
2758
2859 /**
29 * @returns {boolean}
60 * Checks if the triangle is scalene (all sides different).
61 * @returns {boolean} True if the triangle is scalene, false otherwise.
62 * Handled Edge Cases: Invalid triangle (sides <= 0, violates triangle inequality), all sides different
3063 */
3164 get isScalene() {
32 throw new Error('Remove this line and implement the function');
65 const [a, b, c] = this.sides;
66
67 // Edge Case: Check if it's a valid triangle
68 if (!this._isValidTriangle()) {
69 return false;
70 }
71
72 // Edge Case: All sides must be different for a scalene triangle
73 return a !== b && b !== c && a !== c;
74 }
75
76 /**
77 * Helper method to check if the sides form a valid triangle.
78 * @returns {boolean} True if the sides form a valid triangle, false otherwise.
79 * Handled Edge Cases: Sides <= 0, violates triangle inequality
80 */
81 _isValidTriangle() {
82 const [a, b, c] = this.sides;
83
84 // Edge Case: All sides must be greater than 0
85 if (a <= 0 || b <= 0 || c <= 0) {
86 return false;
87 }
88
89 // Edge Case: Check triangle inequality: sum of any two sides must be >= third side
90 if (a + b < c || b + c < a || a + c < b) {
91 return false;
92 }
93
94 return true;
3395 }
3496}
Test NameStatus
all sides are equal
Pass
any side is unequal
Pass
no sides are equal
Pass
all zero sides is not a triangle
Pass
sides may be floats
Pass
last two sides are equal
Pass
first two sides are equal
Pass
first and last sides are equal
Pass
equilateral triangles are also isosceles
Pass
no sides are equal
Pass
first triangle inequality violation
Pass
second triangle inequality violation
Pass
third triangle inequality violation
Pass
sides may be floats
Pass
no sides are equal
Pass
all sides are equal
Pass
first and second sides are equal
Pass
first and third sides are equal
Pass
second and third sides are equal
Pass
may not violate triangle inequality
Pass
sides may be floats
Pass

© 2025 Ridges AI. Building the future of decentralized AI development.