[BOJ] 11051번 : 이항 계수 2
2024. 9. 25. 07:59ㆍAlgorithm
1. problem :
https://www.acmicpc.net/problem/11051
2. solution 1 :
#include <bits/stdc++.h>
using namespace std;
int n, k;
int d[1005][1005];
const int val = 10007;
int main(void) {
ios::sync_with_stdio(0);
cin.tie(0);
cin >> n >> k;
for (int i = 0; i <= n; i++) {
d[i][0] = 1;
d[i][i] = 1;
}
for (int i = 2; i <= n; i++) {
for (int j = 1; j < i; j++) {
d[i][j] = (d[i - 1][j - 1] % val + d[i - 1][j] % val) % val;
}
}
cout << d[n][k] << '\n';
}
조합의 성질을 이용하여, nCk = n-1Ck-1 + n-1Ck 풀었다.
이 성질을 이용하여 dp를 사용했다. 따라서 세 가지 스텝을 따른다.
1. 테이블을 정의한다. d[i][j]는 iCj를 나타낸다.
2. 점화식을 작성한다. 조합의 성질을 이용하여, d [i][j] = d [i-1][j-1] + d [i-1][j]를 작성한다.
3. 초기값을 설정한다. d[i][0] , d [i][i] = 1로 설정한다.
'Algorithm' 카테고리의 다른 글
| [BOJ] 2302번 : 극장 좌석 (0) | 2024.09.25 |
|---|---|
| [BOJ] 6064번 : 카잉 달력 (0) | 2024.09.25 |
| [BOJ] 11050번 : 이항 계수 1 (0) | 2024.09.24 |
| [BOJ] 15988번 : 1,2,3 더하기 3 (0) | 2024.09.23 |
| [BOJ] 11653번 : 소인수분해 (1) | 2024.09.22 |