2차원 좌표 평면에 변이 축과 평행한 직사각형이 있습니다. 직사각형 네 꼭짓점의 좌표 [[x1, y1], [x2, y2], [x3, y3], [x4, y4]]가 담겨있는 배열 dots
가 매개변수로 주어질 때, 직사각형의 넓이를 return 하도록 solution 함수를 완성해보세요.
dots
의 길이 = 4dots
의 원소의 길이 = 2dots[i]
의 원소 < 256dots | result |
---|---|
[[1, 1], [2, 1], [2, 2], [1, 2]] | 1 |
[[-1, -1], [1, 1], [1, -1], [-1, 1]] | 4 |
입출력 예 #1
입출력 예 #2
function solution(dots) {
const result = Math.abs((dots[1][0] - dots[0][0]) * (dots[2][1] - dots[1][1]))
return result
}
function solution(dots) {
return Math.abs(
(Math.max(...dots.map((dot) => dot[0])) -
Math.min(...dots.map((dot) => dot[0]))) *
(Math.max(...dots.map((dot) => dot[1])) -
Math.min(...dots.map((dot) => dot[1])))
);
}
입출력 예시를 보여준 걸로 그냥 시계 방향으로 좌표가 제시될 거라 추측했던 게 오판이었다. 실제로 코드 제출하면서 테스트 돌려보니까 전부 오류가 발생했다.
다른 사람 풀이를 확인해보면 x좌표의 가장 큰 값과 작은 값의 차이와 그리고 y좌표의 가장 큰 값과 작은 값의 차이를 곱하고 음수일 수도 있으니 절대값으로 마무리하는 방식이다.
이 방식으로 해결했어야 하는데 너무 성급했다. 반성한다ㅜ