https://www.acmicpc.net/problem/10801
10801번: 카드게임
두 사람 A와 B는 1부터 10까지의 숫자가 하나씩 적힌 열 장의 카드로 ‘게임’을 한다. 게임은 총 열 번의 ‘라운드’로 구성되고, 각 라운드 마다 자신이 가지고 있는 카드 중 하나를 제시하고,
www.acmicpc.net
c++로 백준 10801번 문제를 풀어보겠다.
문제
두 사람 A와 B는 1부터 10까지의 숫자가 하나씩 적힌 열 장의 카드로 ‘게임’을 한다. 게임은 총 열 번의 ‘라운드’로 구성되고, 각 라운드 마다 자신이 가지고 있는 카드 중 하나를 제시하고, 한 번 제시한 카드는 버린다. 게임 승패는 다음과 같이 결정된다.
- 각 라운드는 더 높은 숫자를 제시한 사람이 승리하고, 제시한 숫자가 같은 경우는 비긴다.
- 열 번의 라운드에서 더 많은 라운드를 승리한 사람이 게임을 승리하고, 승리한 라운드 횟수가 동일한 경우 비긴다.
다음은 게임의 한 예로, 각 라운드마다 A와 B가 제시한 카드의 숫자와 각 라운드의 승자를 보여준다. (비긴 라운드는 D로 표시함)
라운드12345678910A의 카드B의 카드라운드 승자6 | 7 | 5 | 1 | 4 | 10 | 2 | 3 | 8 | 9 |
1 | 10 | 2 | 9 | 4 | 8 | 3 | 7 | 5 | 6 |
A | B | A | B | D | A | B | B | A | A |
A는 5번의 라운드에서 승리하고 B는 4번의 라운드에서 승리하였으므로, 이 게임은 A가 승리한다.
라운드 순서대로 A와 B가 제시한 카드의 숫자가 주어졌을 때, 게임의 승자를 판단하는 프로그램을 작성하시오.
입력
첫 번째 줄에는 A가 제시한 카드의 숫자 10개가 라운드 순서대로 주어지고, 두 번째 줄에는 B가 제시한 카드의 숫자 10개가 라운드 순서대로 주어진다.
출력
게임의 승패가 결정되는 경우 승리한 사람을 출력하고, 비기는 경우에는 D를 출력한다.
예제 입력 1 복사
6 7 5 1 4 10 2 3 8 9
1 10 2 9 4 8 3 7 5 6
예제 출력 1 복사
A
<문제 풀이>
1. 배열 A를 선언한 후, 숫자를 10개 입력받아 배열에 저장한다.
2. 배열 B를 선언한 후, 숫자를 10개 입력받아 배열에 저장한다.
3. 배열 A, B에 들어있는 숫자들 중 같은 위치에 저장된 숫자들끼리 비교해 어느 숫자가 더 큰 지 계산한다.
4. 최종적으로 계산한 A, B 값에 대하여 A가 B보다 크다면 'A'를 출력하고, A와 B가 같다면 'D'를 출력하고, A가 B보다 작다면 'B'를 출력한다.
코드는 다음과 같다.

'C++' 카테고리의 다른 글
[백준 알고리즘] 4592번 : 중복을 없애자, c++ (0) | 2022.03.05 |
---|---|
[백준 알고리즘] 11816번 : 8진수, 10진수, 16진수, c++ (0) | 2022.03.05 |
[백준 알고리즘] 9243번 : 파일 완전 삭제, c++ (0) | 2022.03.04 |
[백준 알고리즘] 3058번 : 짝수를 찾아라, c++ (0) | 2022.03.04 |
[백준 알고리즘] 2702번 : 초6 수학, c++ (0) | 2022.03.03 |