Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 백준
- winapi
- RVO
- IFileDialog
- DirectX11
- softeer
- 프로그래머스
- algorithm
- 언리얼엔진5
- GeeksForGeeks
- const
- RootMotion
- 티스토리챌린지
- DeferredRendering
- 팰린드롬 만들기
- 1563
- Unreal Engine5
- baekjoon
- 줄 세우기
- C
- C++
- directx
- UE5
- 오블완
- NRVO
- Programmers
- Frustum
- UnrealEngine4
- 2294
- UnrealEngine5
Archives
- Today
- Total
Game Develop
[Algorithm] Baekjoon 2407번 : 조합 본문
https://www.acmicpc.net/problem/2407
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
string dp[106][106]; // 뒤집어서 저장되어있음.
string Add(string a, string b) // 각 수는 뒤집혀서 들어옴.
{
string result = "";
int sum = 0;
int maxSize = max(a.size(), b.size());
int aSize = a.size();
int bSize = b.size();
int index = 0;
while (1)
{
if (index < aSize)
{
sum += a[index] - '0';
}
if (index < bSize)
{
sum += b[index] - '0';
}
result.push_back((sum % 10) + '0');
sum = sum / 10;
index++;
if (sum == 0 && index >= maxSize) break;
}
return result;
}
string Combination(int n, int m)
{
if (m == 0 || n == m) return "1";
string& str = dp[n][m];
if (str != "") return str;
str = Add(Combination(n - 1, m - 1), Combination(n - 1, m));
return str;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int n = 0;
int m = 0;
cin >> n >> m;
string result = Combination(n, m);
reverse(result.begin(), result.end());
cout << result << endl;
}
|
cs |
문제자체는 매우 심플하다. nCm 구하는 문제.
기본공식은 nCm = n! / r!(n-r)! 으로, 굉장히 쉬워보이지만 실제로 팩토리얼 계산하려하면 터진다.
20!만해도 단위가 unsigned long long 이랑 비슷해진다.
당연히 팩토리얼로 계산하면 안되고, nCm에는 또다른 규칙이 존재한다.
nCm = n-1Cm-1 + n-1Cm
nCn == 1 , nC0 == 1.
재귀방식으로 풀어야하며, 당연히 한번 풀었던 값에대해서는 기록을 해놔야 스택메모리가 안터진다.
dp문제라고도 볼 수 있다.
값이 매우 크기 때문에 string으로 계산해서 풀어야 한다.
나같은 경우 Add를 호출할때마다 reverse를 하는것도 비용이 크다고 생각해서 reverse를 호출 안하게 구현해봤다.
Add의 두 매개변수는 뒤집혀서 들어온다고 가정하고 코드를 짰다.
예전에 비슷한 문제 풀때는 더 하드코딩식으로 짰던거 같은데, 앞으로는 저렇게 코드를 짤 거 같다.
개인적인 생각이지만 아마 저렇게 짜면 타임아웃이 나진 않을거다.
문제를 풀면 풀수록, 내가 코테에서 왜 떨어졌는지 너무 잘 알게된다..
'Algorithm > Baekjoon' 카테고리의 다른 글
[Algorithm] Baekjoon 11053번 : 가장 긴 증가하는 부분수열 (0) | 2022.12.03 |
---|---|
[Algorithm] Baekjoon 15666번 : N과M (12) (0) | 2022.12.03 |
[Algorithm] Baekjoon 11870번 : 좌표 압축 (0) | 2022.11.29 |
[Algorithm] Baekjoon 11047번 : 동전 0 (0) | 2022.11.29 |
[Algorithm] Baekjoon 9461번 : 파도반 수열 (0) | 2022.11.29 |