😈 직사각형 넓이 구하기
📗 문제 설명
2차원 좌표 평면에 변이 축과 평행한 직사각형이 있습니다. 직사각형 네 꼭짓점의 좌표 [[x1, y1], [x2, y2], [x3, y3], [x4, y4]]가 담겨있는 배열 dots
가 매개변수로 주어질 때, 직사각형의 넓이를 return 하도록 solution 함수를 완성해보세요.
👀 제한사항
dots
의 길이 = 4dots
의 원소의 길이 = 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입니다.
💎나의 풀이
2차원 좌표문제다. 어렵게 생각안해도 된다. 넓이만 구하면 되니,
x,y 각각의 좌표에서 max값과 min 값을 빼주면 길이가 나오니 곱해주자.
const solution = dots => (Math.max(...dots.map(v=>v[0]))-Math.min(...dots.map(v=>v[0])))*(Math.max(...dots.map(v=>v[1]))-Math.min(...dots.map(v=>v[1])))
코드가 지저분해 보인다.
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[프로그래머스 😈] JavaScript 배열의 길이에 따라 다른 연산하기 (0) | 2023.10.24 |
---|---|
[프로그래머스 😈] JavaScript 저주의 숫자 (0) | 2023.10.24 |
[프로그래머스 😈] JavaScript 로그인 성공? (0) | 2023.10.24 |
[프로그래머스 😈] JavaScript 치킨 쿠폰 (0) | 2023.10.24 |
[프로그래머스 😈] JavaScript 등수 매기기 (0) | 2023.10.24 |