Post

[C++]백준 14613번 너의 티어는?

[C++]백준 14613번 너의 티어는?

📌문제 링크


https://www.acmicpc.net/problem/14613

스크린샷 2025-01-05 오후 4 37 19

📌문제 설명


dp[i][j] -> 게임횟수, 점수에 도달할 확률 dp배열 설정 후 게임을 20번 진행했을때 각 티어별 점수의 확률을 전부 더해서 출력해주면 됩니다.

📌코드


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
62
63
64
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

// W: 승리 확률, L: 패배 확률, D: 무승부 확률
// dp[게임횟수][레이팅]: 해당 게임횟수와 레이팅에 도달할 확률
double W, L, D, dp[21][3500];

// 입력 함수
void input(){
    cin >> W >> L >> D;
}

void solve(){
    // 소수점 8자리까지 출력하도록 설정
    cout << fixed;
    cout.precision(8);
    input();
    
    // 초기 레이팅 2000에서 시작하므로 확률 1로 설정
    dp[0][2000] = 1;
    
    // 20게임 동안의 확률 계산
    for(int i = 1; i <= 20; i++){
        for(int j = 1000; j <= 3000; j++){
            dp[i][j - 50] += dp[i - 1][j] * L;    // 패배시 레이팅 50 감소
            dp[i][j] += dp[i - 1][j] * D;         // 무승부시 레이팅 변화없음
            dp[i][j + 50] += dp[i - 1][j] * W;    // 승리시 레이팅 50 증가
        }
    }
    
    // 각 티어별 확률 변수 선언
    double bronze = 0, silver = 0, gold = 0, platinum = 0, diamond = 0, master = 0;
    
    // 20게임 후의 최종 레이팅에 따른 티어 분류
    for(int i = 1000; i <= 3000; i++){
        if(i <= 1499){                // 브론즈: 1000-1499
            bronze += dp[20][i];
        }
        else if(i <= 1999){          // 실버: 1500-1999
            silver += dp[20][i];
        }
        else if(i <= 2499){          // 골드: 2000-2499
            gold += dp[20][i];
        }
        else if(i <= 2999){          // 플래티넘: 2500-2999
            platinum += dp[20][i];
        }
        else if(i <= 3499){          // 다이아몬드: 3000-3499
            diamond += dp[20][i];
        }
    }
    cout << bronze << '\n' << silver << '\n' << gold << '\n' << platinum << '\n' << diamond << '\n';
}

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    solve();
    return 0;
}

This post is licensed under CC BY 4.0 by the author.