Blog

피자 나눠 먹기 (2)

문제 #

머쓱이네 피자가게는 피자를 여섯 조각으로 잘라 줍니다. 피자를 나눠먹을 사람의 수 n이 매개변수로 주어질 때, n명이 주문한 피자를 남기지 않고 모두 같은 수의 피자 조각을 먹어야 한다면 최소 몇 판을 시켜야 하는지를 return 하도록 solution 함수를 완성해보세요.

  • 제한사항

    1 ≤ n≤ 100

  • 입출력 예

    n result
    6 1
    10 5
    4 2

문제분석 #

피자판수와 사람수의 최대공배수를 구하는 문제이다.

나의 풀이 #

class Solution {
    public int solution(int n) {
        int answer = 0;
        int piece = 1;
        
        //answer*6조각=n*x조각이 성립
        //1<=x<=6
        
        while (n*piece%6 != 0){
            piece++;
        }
        answer = n*piece/6;
        
        return answer;
    }
}

다른 사람의 풀이 #

class Solution {
    public int GCD(int num1, int num2) {
        if (num1 % num2 == 0)
            return num2;
        return GCD(num2, num1 % num2);
    }

    public int LCM(int num1, int num2) {
        return num1 * num2 / GCD(num1, num2);
    }

    public int solution(int n) {
        return LCM(n, 6) / 6;
    }
}

관련개념 학습 #

[[]]