Programers 5장 - Lv.0 직사각형 넓이 구하기
포스트
취소

Programers 5장 - Lv.0 직사각형 넓이 구하기

구슬을 나누는 경우의 수

문제

  • 2차원 좌표 평면에 변이 축과 평행한 직사각형이 있습니다.
  • 직사각형 네 꼭짓점의 좌표 [[x1, y1], [x2, y2], [x3, y3], [x4, y4]]가 담겨있는 배열 dots가 매개변수로 주어질 때, 직사각형의 넓이를 return 하도록 solution 함수를 완성해보세요.
1
function solution(dots) {}

제한사항

  • dots의 길이 = 4
  • dots의 원소의 길이 = 2
  • -256 < dots[i]의 원소 < 256
  • 잘못된 입력은 주어지지 않습니다.

입출력 예시

dotsresult
[[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입니다.

내가 짠 코드

1
2
3
4
5
6
7
8
function solution(dots) {
  let width =
    Math.max(...dots.map((el) => el[0])) - Math.min(...dots.map((el) => el[1]));
  let height =
    Math.max(...dots.map((el) => el[1])) - Math.min(...dots.map((el) => el[1]));

  return width * height;
}

코드 설명

  • 가로는 x를 나타내는 dots[0] 중 가장 큰 값과 가장 작은 값의 차다.
  • 새로는 y를 나타내는 dots[1] 중 가장 큰 값과 가장 작은 값의 차다.
  • 가로와 세로를 곱한다.
이 기사는 저작권자의 CC BY 4.0 라이센스를 따릅니다.