프로그래머스/JAVA/직사각형 넓이 구하기

Seoung Young Oh·2022년 12월 26일
0

프로그래머스

목록 보기
87/105
post-thumbnail

문제설명

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 maxX = -256;
        int minX = 256; 
        int maxY = -256;
        int minY = 256;
                
        for (int i = 0; i < dots.length; i++) {
			if(dots[i][0]>maxX) {
				maxX=dots[i][0];
			}
			if(dots[i][0]<minX) {
				minX=dots[i][0];
			}
			if(dots[i][1]>maxY) {
				maxY=dots[i][1];
			}
			if(dots[i][1]<minY) {
				minY=dots[i][1];
			}
		}
        
        return (maxX-minX)*(maxY-minY);
    }
}

참고

0개의 댓글

관련 채용 정보