프로그래머스, 자바스크립트) 구슬을 나누는 경우의 수

2024. 2. 25. 16:40·개발/알고리즘(코딩테스트)

문제

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

 

프로그래머스

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

programmers.co.kr

 

해설

공식을 코드로 구현하면 된다.

function solution(balls, share) {
  //팩토리얼 함수
  const factorial = (n) => {
    let result = 1;
    for (let i = 1; i <= n; i++) {
      result *= i;
    }
    return result;
  };

  //조합 함수
  const combination = (n, r) => {
    // 정수 나누기 연산을 사용
    return factorial(n) / (factorial(r) * factorial(n - r));
  };

  // 정수 값으로 반환되도록 수정
  return Math.round(combination(balls, share));
}

 

다른 풀이

팩토리얼을 재귀함수로 구현

const 팩토리얼 = (num) => num === 0 ? 1 : num * 팩토리얼(num - 1)

function solution(balls, share) {
  return Math.round(팩토리얼(balls) / 팩토리얼(balls - share) / 팩토리얼(share))
}
저작자표시 비영리 변경금지 (새창열림)

'개발 > 알고리즘(코딩테스트)' 카테고리의 다른 글

프로그래머스, 자바스크립트) 삼각형의 완성조건 (2)  (0) 2024.03.02
프로그래머스, 자바스크립트) 배열 만들기 6  (0) 2024.02.26
프로그래머스, 자바스크립트) 배열 만들기 4  (0) 2024.02.25
프로그래머스, 자바스크립트) 조건에 맞게 수열 변환하기 2  (0) 2024.02.22
프로그래머스, 자바스크립트) 수열과 구간 쿼리 4  (0) 2024.02.19
'개발/알고리즘(코딩테스트)' 카테고리의 다른 글
  • 프로그래머스, 자바스크립트) 삼각형의 완성조건 (2)
  • 프로그래머스, 자바스크립트) 배열 만들기 6
  • 프로그래머스, 자바스크립트) 배열 만들기 4
  • 프로그래머스, 자바스크립트) 조건에 맞게 수열 변환하기 2
빔네모
빔네모
console.log("빔네모")
  • 빔네모
    bimnemo("개발")
    빔네모
  • 전체
    오늘
    어제
    • 기록 (143)
      • 기술 (36)
        • JavaScript (1)
        • TypeScript (9)
        • React.js (10)
        • Next.js (0)
        • 라이브러리,도구 (3)
        • HTML,CSS (4)
        • CS (5)
        • BE (4)
      • 개발 (95)
        • 프로젝트 (0)
        • 트러블슈팅 (5)
        • 알고리즘(코딩테스트) (90)
      • 정보 (4)
      • 취미 (8)
        • 감상 (8)
  • 인기 글

  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
빔네모
프로그래머스, 자바스크립트) 구슬을 나누는 경우의 수
상단으로

티스토리툴바