• 목록 (128)
    • Android (62)
    • Back-End (2)
    • Java (3)
    • Kotlin (16)
    • CS (7)
    • 개발 서적 (12)
    • 문제 풀이 (26)

최근 글

티스토리

전체 방문자
오늘
어제
hELLO · Designed By 정상우.
MJ_94
문제 풀이

[프로그래머스/Kotlin] 최소직사각형

[프로그래머스/Kotlin] 최소직사각형
문제 풀이

[프로그래머스/Kotlin] 최소직사각형

2022. 1. 21. 11:47

문제 설명

이와 세로 길이를 조사했습니다.

아래 표는 4가지 명함의 가로길이와 세로 길이를 나타냅니다.

명함 번호 가로 길이 세로 길이
1 60 50
2 30 70
3 60 30
4 80 40

 
가장 긴 가로 길이와 세로 길이가 각각 80, 70이기 때문에 80(가로) x 70(세로) 크기의 지갑을 만들면 모든 명함들을 수납할 수 있습니다. 하지만 2번 명함을 가로로 눕혀 수납한다면 80(가로) x 50(세로) 크기의 지갑으로 모든 명함들을 수납할 수 있습니다. 이때의 지갑 크기는 4000(=80 x 50)입니다.

모든 명함의 가로 길이와 세로 길이를 나타내는 2차원 배열 sizes가 매개변수로 주어집니다. 모든 명함을 수납할 수 있는 가장 작은 지갑을 만들 때, 지갑의 크기를 return 하도록 solution 함수를 완성해주세요.

제한 사항

  • sizes의 길이는 1 이상 10,000 이하입니다.
  • sizes의 원소는 [w, h] 형식입니다.
  • w는 명함의 가로 길이를 나타냅니다.
  • h는 명함의 세로 길이를 나타냅니다.
  • w와 h는 1 이상 1,000 이하인 자연수입니다.

입출력 예

sizes result
[[60, 50], [30, 70], [60, 30], [80, 40]] 4000
[[10, 7], [12, 3], [8, 15], [14, 7], [5, 15]] 120
[[14, 4], [19, 6], [6, 16], [18, 7], [7, 11]] 133

 

입출력 예 설명

입출력 예 #1
문제 예시와 같습니다.

입출력 예 #2
명함들을 적절히 회전시켜 겹쳤을 때, 3번째 명함(가로: 8, 세로: 15)이 다른 모든 명함보다 크기가 큽니다. 따라서 지갑의 크기는 3번째 명함의 크기와 같으며, 120(=8 x 15)을 return 합니다.

입출력 예 #3
명함들을 적절히 회전시켜 겹쳤을 때, 모든 명함을 포함하는 가장 작은 지갑의 크기는 133(=19 x 7)입니다.


풀이

class Solution {

        fun solution(sizes: Array<IntArray>): Int {

        var maxOfWidth = 0
        var maxOfHeight = 0

        sizes.map { arr ->
            val width = arr.first()
            val height = arr.last()

            if (height > width) {
                arr[0] = height
                arr[1] = width
            }

            maxOfWidth = if (arr[0] > maxOfWidth) arr[0] else maxOfWidth 
            maxOfHeight = if (arr[1] > maxOfHeight) arr[1] else maxOfHeight
        }

        return maxOfWidth.times(maxOfHeight)
    }
}
저작자표시 비영리 변경금지 (새창열림)

'문제 풀이' 카테고리의 다른 글

[프로그래머스/Kotlin] 2016년  (0) 2022.01.21
[프로그래머스/Kotlin] 두 개 뽑아서 더하기  (0) 2022.01.21
[프로그래머스/Kotlin] 신고 결과 받기  (0) 2022.01.18
[프로그래머스/Kotlin] 3진법 뒤집기  (0) 2022.01.17
[프로그래머스/Kotlin] 약수의 개수와 덧셈  (0) 2022.01.14
    '문제 풀이' 카테고리의 다른 글
    • [프로그래머스/Kotlin] 2016년
    • [프로그래머스/Kotlin] 두 개 뽑아서 더하기
    • [프로그래머스/Kotlin] 신고 결과 받기
    • [프로그래머스/Kotlin] 3진법 뒤집기
    MJ_94
    MJ_94
    안드로이드, 개발 관련 기술 블로그

    티스토리툴바

    단축키

    내 블로그

    내 블로그 - 관리자 홈 전환
    Q
    Q
    새 글 쓰기
    W
    W

    블로그 게시글

    글 수정 (권한 있는 경우)
    E
    E
    댓글 영역으로 이동
    C
    C

    모든 영역

    이 페이지의 URL 복사
    S
    S
    맨 위로 이동
    T
    T
    티스토리 홈 이동
    H
    H
    단축키 안내
    Shift + /
    ⇧ + /

    * 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.