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
💡 문제풀이 과정
직사각형 넓이
는가로 * 세로
이다.가로의 길이
는 x좌표 중 제일 큰 값과 x좌표 중 제일 작은 값의 차이이다. 마찬가지로세로의 길이
는 y좌표 중 최고 값과 y좌표 중 최소 값의 차이이다. 따라서Math.max()
와Math.min()
그리고 반복문 등을 이용하여 풀이하였다.
✅ 답안 #1
function solution(dots) {
const [x1, y1] = [
Math.min(...dots.map((v) => v[0])),
Math.min(...dots.map((v) => v[1])),
];
const [x2, y2] = [
Math.max(...dots.map((v) => v[0])),
Math.max(...dots.map((v) => v[1])),
];
return (x2 - x1) * (y2 - y1);
}
✅ 답안 #2
function solution(dots) {
let x = [], y = [];
dots.map((v) => {
x.push(v[0]);
y.push(v[1]);
});
const width = Math.max(...x) - Math.min(...x);
const height = Math.max(...y) - Math.min(...y);
return width * height;
}