티스토리 뷰

코딩테스트 연습 - 직사각형 넓이 구하기

문제 설명


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

제출 코드


2022년 12월 31일

#include <string>
#include <vector>
#include <algorithm>

using namespace std;

int solution(vector<vector<int>> dots) {
    int answer = 0;

    sort(dots.begin(), dots.end());

    answer = (dots[3][0] - dots[0][0]) * (dots[3][1] - dots[0][1]);

    return answer;
}

<aside> ☝ 원소가 순서대로 나왔기 때문에 가로와 세로를 구한 후 곱해서 넓이를 구했다.

</aside>

'😈 알고리즘 > 🖥️ 프로그래머스' 카테고리의 다른 글

🖥️ 치킨 쿠폰  (0) 2023.02.13
🖥️ 문자열 밀기  (0) 2023.02.12
🖥️ 로그인 성공?  (0) 2023.02.10
🖥️ 삼각형의 완성조건 (2)  (0) 2023.02.09
🖥️ 컨트롤 제트 🤔  (0) 2023.02.08
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
«   2025/07   »
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31
링크
Total
Today
Yesterday