https://www.acmicpc.net/problem/12756
문제
"럭키스톤"은 카드를 통해 대결하는 게임이다. 창식이는 럭키스톤을 자주 한다.
이 게임의 카드에는 공격력과 생명력이 표시되어있다. 왼쪽에는 공격력이, 오른쪽에는 생명력이 숫자로 적혀있다.
서로 꺼낸 카드를 비교하여 남길 카드를 결정하는 데, 카드의 비교는 다음과 같이 이루어진다.
- 비교하는 카드의 공격력만큼 동시에 서로 상대 카드의 생명력을 깎는다. 줄어든 생명력은 다시 회복되지 않는다.
- 생명력이 0 이하인 경우에는 카드는 죽은 상태로 전환된다.
- 카드가 두 장 모두 남아있다면 비교를 계속한다.
요즘 따라 게임이 안 풀리는 창식이는 대전 전에 가능한 수를 미리 계산하여 최대한 이득을 챙기고 싶어 한다.
카드 2개의 공격력과 생명력이 주어지면 어떤 플레이어의 카드가 남아있을지 출력하는 프로그램을 작성해주자.
입력
첫째 줄에 플레이어 A가 꺼낸 카드의 공격력과 생명력이 주어진다.
둘째 줄에 플레이어 B가 꺼낸 카드의 공격력과 생명력이 주어진다.
카드의 공격력과 생명력은 100,000 이하의 자연수이다.
출력
플레이어 A의 카드가 남아있다면 "PLAYER A"를, 플레이어 B의 카드가 남아있다면 "PLAYER B"를 출력한다.
모두 죽은 상태라면 "DRAW"를 따옴표 없이 출력한다.
<정답 코드>
a_attack, a_life = map(int, input().split())
b_attack, b_life = map(int, input().split())
while True:
a_life -= b_attack
b_life -= a_attack
if a_life <= 0 or b_life <= 0:
break
if a_life <= 0 and b_life <= 0:
print("DRAW")
elif b_life <= 0:
print("PLAYER A")
elif a_life <= 0:
print("PLAYER B")
<풀이 과정>
먼저 플레이어 A 카드에 공격력과 생명력을 부여하고,
마찬가지로 같은 방법으로 플레이어 B 카드에 공격력과 생명력을 부여한다.
이후 죽음의 맞다이를 시작한다.
바로, while loop을 돌며 A나 B의 생명력이 0이하가 될 때까지 싸움을 계속 하는 것이다.
누구 하나가 쓰려졌을 때가 전투의 종료조건이다.
여기서 3가지 종류의 가능성이 있다.
1. 같은 턴에 A, B가 동시에 죽은 경우.
2. A가 이긴 경우( B의 생명력이 0이 된 경우 )
3. B가 이긴 경우( A의 생명력이 0이 된 경우 )
이때,
1번 케이스의 경우, "DRAW"를 출력
2번 케이스의 경우, "PLAYER A"를 출력
3번 케이스의 경우, "PLAYER B"를 출력
하면 정답을 맞출 수 있다.
'Koala - 14기 > 기초 알고리즘 스터디' 카테고리의 다른 글
[백준/Python] 10824번: 네 수 (0) | 2024.03.23 |
---|---|
[백준/C++] 3003번: 킹, 퀸, 룩, 비숍, 나이트, 폰 (0) | 2024.03.21 |
[백준/JAVA] 11365번 !밀비 급일 (0) | 2024.03.17 |
[백준/python] 4435번 중간계전쟁 (0) | 2024.03.17 |
[백준/Python] 23739 벼락치기 (0) | 2024.03.17 |