CodingTest.プログラマー


問題の説明


level2
じゅうたん
Leoは家に帰ってから、さっき見たじゅうたんの黄色と茶色の格子数を覚えたが、じゅうたん全体の大きさは覚えていない.
Leoがこのカーペットに茶色の格子の数brown,黄色の格子の数yellowをパラメータとして与えた場合,カーペットの横方向と縦方向の寸法を順番に並べて返す解関数を記述してください.

コード#コード#


問題を完全にナビゲートして解決するには,まず対応する幅を求め,次いで順次計算する.
def solution(brown, yellow):

    answer = []
    arr = []
    
    // 브라운과 옐로우 를 합한 네모의 개수가 사각형의 넓이
    s = brown + yellow
    
    // 약수를 구함
    for i in range(s,0,-1):
      if s % i == 0 :
        arr.append([i,s//i])
        
    //arr = [[12, 1], [6, 2], [4, 3], [3, 4], [2, 6], [1, 12]]

    // 약수들의 집합을 곱하기 2한 상태에서 -4 (모서리)를 뺀 넓이가 s일때 
    for i in arr:
      if (i[0] * 2 + i[1] * 2) - 4 == brown:
        // 가로 길이가 세로 길이와 같거나 길다.
        if i[0] >= i[1]:
          answer = i
    
    return answer