[백준] 11051번: 이항 계수 2 - Kotlin[코틀린]

2023. 9. 17. 19:17·알고리즘/Baekjoon

문제

 

 

11051번: 이항 계수 2

첫째 줄에 \(N\)과 \(K\)가 주어진다. (1 ≤ \(N\) ≤ 1,000, 0 ≤ \(K\) ≤ \(N\))

www.acmicpc.net

 


풀이

 

 파스칼 삼각형을 이용해 점화식을 만들고 이항 계수를 계산해주면 된다. 아래의 이미지는 파스칼 삼각형을 쉽게 이해할 수 있도록 설명해 준다.

이미지 출처 - 위키 백과

 파스칼 삼각형은 각 단계의 처음과 끝은 1로 채워주고 그 사이의 항들은 윗 단계에서 더해주는 것으로 계산한다. 이에 대한 수학적 증명은 아래와 같다.

 

$$\displaystyle \binom{n-1}{r-1}+\binom{n-1}{r}=\frac{\left(n-1\right)!}{\left(r-1\right)!\left(n-r\right)!}+\frac{\left(n-1\right)!}{r!\left(n-r-1\right)!}=\frac{\left(n-1\right)!r}{r!\left(n-r\right)!}+\frac{\left(n-1\right)!\left(n-r\right)}{r!\left(n-r\right)!}=\frac{n!}{r!\left(n-r\right)!}=\binom{n}{r}$$

 

 위의 성질을 점화식으로 나타낼 수 있다.

  - dp[i][0] = 1, dp[i][i] = 1

  - dp[i][j] = dp[i - 1][j - 1] + dp[i - 1][j]

 dp 배열을 선언하고 반복문을 통해 점화식 계산을 해주고 10007으로 나눈 값을 출력해주면 된다.

 


코드

 

import java.util.*

fun main() {
    val br = System.`in`.bufferedReader()
    val bw = System.out.bufferedWriter()

    val st = StringTokenizer(br.readLine())
    val num = st.nextToken().toInt()
    val k = st.nextToken().toInt()

    val dp = Array(num + 1){ IntArray(num + 1) }

    for(i in 1 .. num) {
        dp[i][i] = 1
        dp[i][0] = 1
    }
    for(i in 2..num) {
        for (j in 1..i) {
            dp[i][j] = (dp[i - 1][j - 1] + dp[i - 1][j]) % 10007
        }
    }

    bw.write("${dp[num][k]}")
    bw.flush()
    bw.close()
    br.close()
}

 

'알고리즘 > Baekjoon' 카테고리의 다른 글

[백준] 11050번: 이항 계수 1 - Kotlin[코틀린]  (0) 2023.09.20
[백준] 11401번: 이항 계수 3 - Kotlin[코틀린]  (0) 2023.09.18
[백준] 1010번: 다리 놓기 - Kotlin[코틀린]  (0) 2023.08.17
[백준] 10814번: 나이순 정렬 - Kotlin[코틀린]  (0) 2023.08.10
[백준] 1149번: RGB거리 - Kotlin[코틀린]  (0) 2023.08.07
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 11050번: 이항 계수 1 - Kotlin[코틀린]
  • [백준] 11401번: 이항 계수 3 - Kotlin[코틀린]
  • [백준] 1010번: 다리 놓기 - Kotlin[코틀린]
  • [백준] 10814번: 나이순 정렬 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

      에라토스테네스의 체
      그래프이론
      소수 판정
      큐
      우선순위 큐
      브루트포스
      그래프 탐색
      그리디
      정렬
      모듈러 곱셈 역원
      DP
      이분 탐색
      피보나치
      분할 정복
      백트래킹
      재귀
      티스토리
      dfs
      분리집합
      누적 합
      투 포인터
      스택
      BFS
      프림
      MST
      구현
      문자열
      유니온파인드
      수학
      크루스칼
    • hELLO· Designed By정상우.v4.10.2
    junghoooooon
    [백준] 11051번: 이항 계수 2 - Kotlin[코틀린]
    상단으로

    티스토리툴바