[ALGO] 프로그래머스 - 카펫(자바스크립트, javascript)

hj·2021년 7월 1일
0

알고리즘

목록 보기
26/35
post-thumbnail
post-custom-banner

프로그래머스 - 카펫

문제

Leo는 카펫을 사러 갔다가 아래 그림과 같이 중앙에는 노란색으로 칠해져 있고 테두리 1줄은 갈색으로 칠해져 있는 격자 모양 카펫을 봤습니다.

사각형 Leo는 집으로 돌아와서 아까 본 카펫의 노란색과 갈색으로 색칠된 격자의 개수는 기억했지만, 전체 카펫의 크기는 기억하지 못했습니다.

Leo가 본 카펫에서 갈색 격자의 수 brown, 노란색 격자의 수 yellow가 매개변수로 주어질 때 카펫의 가로, 세로 크기를 순서대로 배열에 담아 return 하도록 solution 함수를 작성해주세요.

제한사항

  • 갈색 격자의 수 brown은 8 이상 5,000 이하인 자연수입니다.
  • 노란색 격자의 수 yellow는 1 이상 2,000,000 이하인 자연수입니다.
  • 카펫의 가로 길이는 세로 길이와 같거나, 세로 길이보다 깁니다.

과정

노란색 격자의 세로노란색 격자의 개수 / 2 보다 작거나 같을 때까지 반복문을 돌면서 노란색 격자 개수(yellow)의 약수를 구한다.
구한 약수 2개가 노란색 격자의 가로 = yc, 노란색 격자의 세로 = yr 가 되고, 노란색 격자의 테두리를 감싸는 격자의 수가 갈색 격자의 수와 일치하는 경우 [노란색 격자의 가로 + 2, 노란색 격자의 세로 + 2]를 반환해준다.

노란색 격자의 가로 = yc, 노란색 격자의 세로 = yr 이라고 했을 때, 갈색 격자의 수 = (yc * 2) + (yr * 2) + 4 가 된다.

풀이

function solution(brown, yellow) {
    let answer = [];
    
    // yellow row(가로), yellow col(세로)
    let yr = 1;
    let yc = yellow;
    
    while (yr <= parseInt(yellow / 2)) {
        if ((yellow % yr) === 0) {
            yc = parseInt(yellow / yr);
            
            const tmp = (yc * 2) + (yr * 2) + 4;
            if ((tmp === brown) && ((yc + 2) >= (yr + 2))) {
                break;
            }
            
        } 
        yr += 1;
    }
    
    return [(yc + 2), (yr + 2)];
}
post-custom-banner

0개의 댓글