728x90
문제 설명
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입니다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
class Solution {
public int solution(int[][] dots) {
int answer = 0;
int xmin = 256, xmax = -256, ymin = 256, ymax = -256;
for(int i=0;i<dots.length;i++) {
if(dots[i][0]<xmin) xmin = dots[i][0];
if(dots[i][1]<ymin) ymin = dots[i][1];
if(dots[i][0]>xmax) xmax = dots[i][0];
if(dots[i][1]>ymax) ymax = dots[i][1];
}
answer = (xmax-xmin) * (ymax-ymin);
return answer;
}
}
|
cs |
4개의 꼭지점이므로 가로와 세로의 길이를 구해서 곱해주면 답이다. 가로 = x좌표의 최대값 - x좌표의 최소값 세로 = y좌표의 최대값 - y좌표의 최소값 넓이 = 가로 * 세로 |
728x90
'프로그래머스 코딩(자바) > Level 0' 카테고리의 다른 글
Programmers Level 0 - 치킨 쿠폰 (0) | 2023.03.07 |
---|---|
Programmers Level 0 - 로그인 성공? (0) | 2023.03.07 |
Programmers Level 0 - 종이 자르기 (0) | 2023.03.07 |
Programmers Level 0 - 캐릭터의 좌표 (0) | 2023.03.07 |
Programmers Level 0 - 외계어 사전 (0) | 2023.03.06 |