문제 설명
2차원 좌표 평면에 변이 축과 평행한 직사각형이 있습니다. 직사각형 네 꼭짓점의 좌표 [[x1, y1], [x2, y2], [x3, y3], [x4, y4]]가 담겨있는 배열 dots가 매개변수로 주어질 때, 직사각형의 넓이를 return 하도록 solution 함수를 완성해보세요.
제한사항
- dots의 길이 = 4
- dots의 원소의 길이 = 2
- -256 < dots[i]의 원소 < 256
- 잘못된 입력은 주어지지 않습니다.
입출력 예
dots | result |
[[1, 1], [2, 1], [2, 2], [1, 2]] | 1 |
[[-1, -1], [1, 1], [1, -1], [-1, 1]] | 4 |
입출력 예 설명
입출력 예 #1
- 좌표 [[1, 1], [2, 1], [2, 2], [1, 2]] 를 꼭짓점으로 갖는 직사각형의 가로, 세로 길이는 각각 1, 1이므로 직사각형의 넓이는 1 x 1 = 1입니다.
입출력 예 #2
- 좌표 [[-1, -1], [1, 1], [1, -1], [-1, 1]]를 꼭짓점으로 갖는 직사각형의 가로, 세로 길이는 각각 2, 2이므로 직사각형의 넓이는 2 x 2 = 4입니다.
나의 풀이
function solution(dots) {
// 주어지는 꼭짓점의 자표 순서가 다름
let answer = 0;
const x = [] // dots의 x좌표를 모을 배열 생성
const y = [] // dots의 y좌표를 모을 배열 생성
dots.forEach((dot)=>{ // dots를 dot으로 순회합니다.
x.push(dot[0]) // dot[0]값은 x에 push를 해줍니다.
y.push(dot[1]) // dot[1]값은 y에 push를 해줍니다.
})
answer = (Math.max(...x)+(Math.min(...x)*-1)) * (Math.max(...y)+(Math.min(...y)*-1))
// answer에는 (x배열에서 가장큰값 + x배열에서 가장 작은값 * -1) * (y배열에서 가장큰값 + y배열에서 가장 작은값 * -1)
return answer;
}
'코딩 테스트 풀이 🛠' 카테고리의 다른 글
[프로그래머스] 시저 암호 (0) | 2023.03.08 |
---|---|
[프로그래머스] 숫자의 표현 (0) | 2023.03.08 |
[프로그래머스] 이상한 문자 만들기 (0) | 2023.03.05 |
[프로그래머스] OX퀴즈 (0) | 2023.03.05 |
[프로그래머스] 이진 변환 반복하기 (0) | 2023.03.02 |