문제 링크
https://www.acmicpc.net/problem/17264
문제
다들 문제 제목을 보고 요즘 가장 핫한 영화를 생각했겠지만 이 이야기는 LUL(League Us Legends) 게임에서 아이언(Iron) 티어에 있는 형동이의 슬픈 이야기이다. LUL에서 티어는 게임 실력을 판가름할 수 있는 지표이다. 그중 아이언 티어는 가장 낮은 단계에 위치해 있다. 친구인 강엽이와 건홍이에게 “Ironman”이라며 게임을 못한다고 놀림당하던 형동이는 꼭 아이언 티어에서 벗어나겠다고 결심했다. 하지만 형동이는 자신의 실력으로 절대 아이언(Iron) 티어에서 벗어나지 못하는 것을 알고 있다. LUL은 두 명의 플레이어가 같이 팀이 되어 하는 게임이기 때문에 자신이 못해도 게임에서 이길 수 있고 자신이 잘해도 게임은 질 수 있다. 형동이는 게임은 못하지만 머리가 매우 똑똑하여 LUL 게임을 해킹하여서 몇몇 플레이어와 같이 게임을 하게 되면 게임의 승패가 어떻게 되는지 알게 되었다. 하지만 해킹을 통하여 알아내지 못한 플레이어와 같이 게임을 하는 경우 형동이가 매우 못하기 때문에 같은 팀원이 아무리 잘해도 반드시 진다.
위와 같은 경우에서 “JIHOON”과 같이 게임을 하는 경우 20점(W = 20)을 획득하는 반면에 “GANGYEOP”이나 “MINSUNG”과 같이 게임 하는 경우 경우 15점(L = 15)을 잃게 된다. 뿐만 아니라, 해킹을 통해 알지 내지 못한 플레이어를 만나게 되는 경우 형동이가 매우 못하여 지기 때문에 15점을 잃게 된다. (단, 계속 지더라도 점수는 0점 밑으로 떨어지지 않는다.)
형동이가 N번에 게임을 통해서 아이언 티어에서 탈출한 경우 형동이는 “I AM NOT IRONMAN”이라고 외치지만 탈출하지 못한 경우 “I AM IRONMAN”이라고 외친다.
여기서 아이언 티어를 탈출하기 위해서 100점 (G = 100) 이상이 되어야 했다면 9번째 게임(주황색 사각형)을 하고 아이언 티어를 탈출하였기 때문에 형동이는 “I AM NOT IRONMAN”이라고 외친다. 아이언 티어에서 탈출한 경우 그 이후에 게임은 신경쓰지 않는다.
하지만 만약 탈출하기 위해서 200점(G = 200) 이상이 되어야 한다고 했을 경우 형동이는 아이언 티어를 탈출하지 못했기 때문에 “I AM IRONMAN”이라고 외치게 된다.
과연 형동이는 게임이 끝난 후 어떤 대사를 할 지 우리가 맞춰보자.
입력
첫 번째 줄에는 총 게임 횟수 N과 해킹을 통해 얻은 플레이어 정보의 수 P가 주어진다. (N과 P는 1,000이하의 자연수)
그리고 두 번째 줄에는 이긴 경우 획득 점수 W와 졌을 때 떨어지는 점수 L, 그리고 IRON 티어에서 벗어나기 위한 점수 G가 주어진다. (0 ≤ W, L ≤ 100, 1 ≤ G ≤ 100,000, 이 때, W, L, G는 정수)
그리고 다음 P개의 줄에는 플레이어의 이름과 무조건 이길 수 있는 경우 W, 무조건 지는 경우 L이라는 단어가 플레이어 이름과 쌍으로 나온다.
그리고 그 다음 N개의 줄에는 같이 게임을 하는 플레이어의 이름이 나온다.
플레이어 이름은 반드시 대문자로 나오며 길이는 20이 넘지 않는다.
출력
0점부터 시작하였을 때 형동이가 아이언 티어에서 벗어나지 못한 경우 "I AM IRONMAN!!", 아이언 티어에서 벗어난 경우 “I AM NOT IRONMAN!!”을 출력한다.
예제 입력 1
10 3
20 15 100
JIHOON W
GANGYEOP L
MINSUNG L
JIHOON
MYEONGKI
GANGYEOP
MINSUNG
JIHOON
JIHOON
JIHOON
JIHOON
JIHOON
MINSUNG
예제 출력 1
I AM NOT IRONMAN!!
예제 입력 2
10 3
20 15 100
JIHOON W
GANGYEOP L
MINSUNG L
JIHOON
GANGYEOP
JISUP
MINSUNG
JIHOON
JIHOON
MOJI
KYUNGMIN
SOOHO
SEOKGYE
예제 출력 2
I AM IRONMAN!!
알고리즘 분류
- 자료 구조
풀이
해킹한 유저들의 정보를 map 자료구조를 이용해 저장한다.
그리고 N명의 플레이어와 게임을 진행할 때마다 점수 변동을 기록한다.
해킹하지 못 한 플레이어와 할 때에는 점수가 무조건 L만큼 깎이게 된다.
게임을 하면서 한 번이라도 G점 이상이 되었다면 아이언맨이 아니게 되고, G점을 넘은 적이 없다면 아이언맨이 된다.
코드
#include <iostream>
#include <string>
#include <cmath>
#include <set>
#include <unordered_map>
#include <bitset>
#include <ctime>
#include <stack>
#include <queue>
#include <vector>
#include <algorithm>
#include <climits>
#define FASTIO cin.tie(NULL); cout.tie(NULL); ios::sync_with_stdio(false);
#define MAX 5
#define LL long long
#define INF 1e9
using namespace std;
int N, P, W, L, G;
unordered_map<string, int> MAP;
int Score = 0;
bool Answer = false;
void Input() {
cin >> N >> P;
cin >> W >> L >> G;
for (int i = 0; i < P; i++) {
string Name, Result;
cin >> Name >> Result;
if (Result == "W") {
MAP.insert(make_pair(Name, W));
}
else if (Result == "L") {
MAP.insert(make_pair(Name, -L));
}
}
}
void Settings() {
for (int i = 0; i < N; i++) {
string Name;
cin >> Name;
if (MAP.find(Name) != MAP.end()) {
Score += MAP[Name];
}
else {
Score -= L;
}
if (Score < 0) {
Score = 0;
}
else if (Score >= G) {
Answer = true;
}
}
}
void Find_Answer() {
if (Answer) {
cout << "I AM NOT IRONMAN!!\n";
}
else {
cout << "I AM IRONMAN!!\n";
}
}
int main() {
FASTIO
Input();
Settings();
Find_Answer();
return 0;
}
'BOJ > Silver' 카테고리의 다른 글
[BOJ/Silver 3] 백준 1614 영식이의 손가락(C++) (0) | 2022.05.26 |
---|---|
[BOJ/Silver 3] 백준 17479 정식당(C++) (0) | 2022.05.16 |
[BOJ/Silver 1] 백준 2002 추월(C++) (0) | 2022.05.06 |
[BOJ/Silver 3] 백준 16165 걸그룹 마스터 준석이(C++) (0) | 2022.05.06 |
[BOJ/Silver 3] 백준 13414 수강신청(C++) (0) | 2022.05.06 |