알고리즘

프로그래머스 구슬을 나누는 경우의 수 (JAVA)

박카스마시며코딩 2022. 11. 2. 21:07

https://school.programmers.co.kr/learn/courses/30/lessons/120840

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

 

 

class Solution {
    private static final int SIZE = 30;
    public int solution(int balls, int share) {
        int answer = 0;
        int[][] dp = new int[SIZE+1][SIZE+1];
        answer = cal(balls,share,dp);
        return answer;
    }
    private int cal(int balls,int share, int[][] dp){
        if(dp[balls][share] != 0){
            return dp[balls][share];
        }
        if(balls == share || share == 0){
            return 1;
        }else{
            return dp[balls][share] = cal(balls-1,share-1,dp) + cal(balls-1,share,dp);
        }
    }
}