츄르사려고 코딩하는 코집사입니다.
1. [백준 알고리즘] 백준 2511번 카드놀이 파이썬(Python)
1) 문제번호 : 2511번
2) 문제 출처
https://www.acmicpc.net/problem/2511
2. 문제
0부터 9까지의 숫자가 표시된 카드를 가지고 두 사람 A와 B가 게임을 한다. A와 B에게는 각각 0에서 9까지의 숫자가 하나씩 표시된 10장의 카드뭉치가 주어진다. 두 사람은 카드를 임의의 순서로 섞은 후 숫자가 보이지 않게 일렬로 늘어 놓고 게임을 시작한다. 단, 게임 도중 카드의 순서를 바꿀 수는 없다.
A와 B 각각이 늘어놓은 카드를 뒤집어서 표시된 숫자를 확인하는 것을 한 라운드라고 한다. 게임은 첫 번째 놓인 카드부터 시작하여 순서대로 10번의 라운드로 진행된다. 각 라운드에서는 공개된 숫자가 더 큰 사람이 승자가 된다. 승자에게는 승점 3점이 주어지고 패자에게는 승점이 주어지지 않는다. 만약 공개된 두 숫자가 같아서 비기게 되면, A, B 모두에게 승점 1점이 주어진다.
10번의 라운드가 모두 진행된 후, 총 승점이 큰 사람이 게임의 승자가 된다. 만약, A와 B의 총 승점이 같은 경우에는, 제일 마지막에 이긴 사람을 게임의 승자로 정한다. 그래도 승부가 나지 않는 경우는 모든 라운드에서 비기는 경우뿐이고 이 경우에 두 사람은 비겼다고 한다.
예를 들어, 다음 표에서 3번째 줄은 각 라운드의 승자를 표시하고 있다. 표에서 D는 무승부를 나타낸다. 이 경우에 A의 총 승점은 16점이고, B는 13점이어서, A가 게임의 승자가 된다.
라운드12345678910AB승
4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 9 | 8 |
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 |
A | A | A | A | B | B | B | B | D | A |
아래 표의 경우에는 A와 B의 총 승점은 13점으로 같다. 마지막으로 승부가 난 라운드는 7번째 라운드이고, 이 라운드의 승자인 B가 게임의 승자가 된다.
라운드12345678910AB승
9 | 1 | 7 | 2 | 6 | 3 | 0 | 4 | 8 | 5 |
6 | 3 | 9 | 2 | 1 | 0 | 7 | 4 | 8 | 5 |
A | B | B | D | A | A | B | D | D | D |
A와 B가 늘어놓은 카드의 숫자가 순서대로 주어질 때, 게임의 승자가 A인지 B인지, 또는 비겼는지 결정하는 프로그램을 작성하시오.
3. 제약사항
4. 입력
입력 파일은 두 개의 줄로 이루어진다. 첫 번째 줄에는 A가 늘어놓은 카드의 숫자들이 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 B가 늘어놓은 카드의 숫자들이 빈칸을 사이에 두고 순서대로 주어진다.
5. 출력
첫 번째 줄에는 게임이 끝난 후, A와 B가 받은 총 승점을 순서대로 빈칸을 사이에 두고 출력한다. 두 번째 줄에는 이긴 사람이 A인지 B인지 결정해서, 이긴 사람을 문자 A 또는 B로 출력한다. 만약 비기는 경우에는 문자 D를 출력한다.
6. 풀이
- 승은 3포인트, 패는 포인트를 못얻고 비길 경우에는 1포인트를 추가한다.
- 그리고, 승패가 결정날 때에는 history 변수를 두어 승패를 기록하고, history에 있는 변수가 곧 마지막에 이긴 사람이다.
- history에 따라 A, B 점수가 같으면 경우의 수에 출력하면 된다.
7. 소스 코드
import sys
input=sys.stdin.readline
A = list(map(int, input().split()))
B = list(map(int, input().split()))
AScore = 0 # A 점수
BScore = 0 # B 점수
history = "D" # 승패 기록
for i in range(10) :
# 비길 경우
if A[i] == B[i] :
AScore += 1
BScore += 1
# A가 이길 경우
if A[i] > B[i] :
AScore += 3
history = "A"
# B가 이길 경우
if A[i] < B[i] :
BScore += 3
history = "B"
# A 스코어가 더 높을 경우
if AScore > BScore :
print(AScore, BScore)
print("A")
# B 스코어가 더 높을 경우
if AScore < BScore :
print(AScore, BScore)
print("B")
# A, B 스코어가 같을 경우
if AScore == BScore :
if history == "A" :
print(AScore, BScore)
print("A")
if history == "B" :
print(AScore, BScore)
print("B")
if history == "D" :
print(AScore, BScore)
print("D")
'알고리즘 > 백준 알고리즘' 카테고리의 다른 글
[백준 알고리즘] 백준 23795번 사장님 도박은 재미로 하셔야 합니다 파이썬(Python) (0) | 2021.12.21 |
---|---|
[백준 알고리즘] 백준 4504번 배수 찾기 파이썬(Python) (0) | 2021.12.20 |
[백준 알고리즘] 백준 4101번 크냐? 파이썬(Python) (0) | 2021.12.20 |
[백준 알고리즘] 백준 2754번 학점계산 파이썬(Python) (0) | 2021.12.20 |
[백준 알고리즘] 백준 2547번 사탕 선생 고창영 파이썬(Python) (0) | 2021.12.19 |
[백준 알고리즘] 백준 2476번 주사위 게임 파이썬(Python) (0) | 2021.12.15 |
[백준 알고리즘] 백준 1547번 공 파이썬(Python) (0) | 2021.12.13 |
[백준 알고리즘] 백준 1267번 핸드폰 요금 파이썬(Python) (0) | 2021.12.07 |
최근댓글