-
[프로그래머스 - 입문] 직사각형 넓이 구하기 - JAVA프로그래머스 문제풀이/Java 문제풀이 2022. 12. 1. 17:38728x90
문제 설명
2차원 좌표 평면에 변이 축과 평행한 직사각형이 있습니다. 직사각형 네 꼭짓점의 좌표 [[x1, y1], [x2, y2], [x3, y3], [x4, y4]]가 담겨있는 배열 dots가 매개변수로 주어질 때, 직사각형의 넓이를 return 하도록 solution 함수를 완성해보세요.
제한사항- 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입니다.
class Solution { public int solution(int[][] dots) { int left = Math.min(Math.min(dots[0][0], dots[1][0]), Math.min(dots[2][0], dots[3][0])); int right = Math.max(Math.max(dots[0][0], dots[1][0]), Math.max(dots[2][0], dots[3][0])); int top = Math.max(Math.max(dots[0][1], dots[1][1]), Math.max(dots[2][1], dots[3][1])); int bottom = Math.min(Math.min(dots[0][1], dots[1][1]), Math.min(dots[2][1], dots[3][1])); return (right - left) * (top - bottom); } }
728x90'프로그래머스 문제풀이 > Java 문제풀이' 카테고리의 다른 글
[프로그래머스 - 입문] 최댓값 만들기 (2) - JAVA (0) 2022.12.01 [프로그래머스 - 입문] 캐릭터의 좌표 - JAVA (0) 2022.12.01 [프로그래머스 - 입문] 머쓱이보다 키 큰 사람 - JAVA (0) 2022.11.30 [프로그래머스 - 입문] 중복된 숫자 개수 - JAVA (0) 2022.11.30 [프로그래머스 - 입문] 잘라서 배열로 저장하기 - JAVA (0) 2022.11.30