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입니다.
나의 풀이
import java.lang.Math;
class Solution {
public int solution(int[][] dots) {
int answer = 0;
int one = dots[0][0] - dots[1][0];
int two = dots[0][1] - dots[1][1];
if(Math.abs(one) == 0) {
one = dots[0][0] - dots[2][0];
}
if(Math.abs(two) == 0) {
two = dots[0][1] - dots[2][1];
}
answer = Math.abs(one) * Math.abs(two);
return answer;
}
}
다른 사람의 풀이
class Solution {
public int solution(int[][] dots) {
int answer = 0;
int tmp = dots[0][0];
int tmp2 = 0;
int tmp3 = 0;
for(int i = 1; i<dots.length; i++){
if(dots[i][0] == tmp){
tmp2 = Math.abs(dots[i][1] - dots[0][1]);
}else{
tmp3 = Math.abs(dots[i][0] - dots[0][0]);
}
}
answer = tmp2 * tmp3;
return answer;
}
}
728x90
반응형
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[프로그래머스][JAVA] 치킨 쿠폰 (LV.0) (0) | 2023.02.13 |
---|---|
[프로그래머스][JAVA] 로그인 성공? (LV.0) (0) | 2023.02.13 |
[프로그래머스][JAVA] 종이 자르기 (LV.0) (0) | 2023.02.13 |
[프로그래머스][JAVA] 캐릭터의 좌표 (LV.0) (0) | 2023.02.13 |
[프로그래머스][JAVA] 외계어 사전 (LV.0) (0) | 2023.02.13 |