https://www.acmicpc.net/problem/17251
문제
과거 격투가로 명성을 떨치던 힘스트롱씨는 "힘 겨루기"라는 대회를 주최하여 전국에 홍보를 하였다. 모집 공고를 보고 전국 각지에서 많은 사람들이 모였는 데, 모집 공고에 '힘'이란 것에 대해 정의하지 않아 혼란이 생긴 것이다.
헬스장에서 3대 500치는 근육질 아저씨부터, 유명 RPG 게임의 힘(STR) 스탯이 높은 사람까지 여러 종류의 힘을 두고 모인 것이다.
힘스트롱씨는 문득 "아는 것이 힘이다"라는 유명 격언이 떠올랐다. 예선전에서 상식 퀴즈를 통해 참가자들의 힘을 수치화하였고, 이 수치를 통해 본선 참가자를 선정하기로 하였다.
그렇게 총 N명의 참가자가 본선에 진출하였다. 하지만 예상과 달리, 본선은 홍팀과 청팀 두 팀으로 나누어 승부를 겨루는 팀전으로 진행되었다.
N명의 참가자들이 일렬로 나란히 서 있다. 힘스트롱씨는 1부터 N−1까지의 수가 적힌 공이 들어있는 추첨 상자에서 무작위로 하나를 뽑아 기준선을 선정할 예정이다. 예를 들어, 3번이 적힌 공을 뽑으면 3번과 4번 참가자 사이가 기준선이 된다. 기준선보다 왼쪽은 홍팀, 기준선보다 오른쪽은 청팀이다.
경기는 단판으로 진행된다. 각 팀에서 가장 센 사람이 나온 후, 두 사람이 힘을 겨룬다. 힘이 더 센 사람이 이기고 게임은 종료된다. 힘의 세기가 같으면 이기는 사람은 없다.
도박사 김씨(이하 김도박사)는 경기가 시작되기 전에 참가자 명단을 입수했다! 기준선의 위치에 따라 어느 팀이 이길 지 미리 알 수 있게 된 김도박사는 이길 확률이 더 높은 쪽에 전재산을 걸 예정이다. 김도박사는 어느 팀에 전재산을 걸어야할까?
기준선은 선수와 선수 사이에만 위치할 수 있으며, 팀에는 반드시 1명 이상 있어야 한다.
입력
첫째 줄에 사람의 수 N이 주어진다. N은 1,000,000보다 작거나 같은 짝수이다.
둘째 줄에 1번 사람부터 N번 사람까지의 힘을 나타내는 정수가 주어진다. 각 사람의 힘은 10,000보다 작거나 같은 자연수이다.
출력
김도박사가 홍팀에 걸어야 하는 경우에는 R, 청팀에 걸어야 하는 경우에는 B를 출력한다. 두 팀의 이길 확률이 같은 경우에는 X를 출력한다.
문제 풀이
가장 큰 수의 위치를 찾으면 되는 문제.
두 팀에서 각각 가장 큰 힘을 가진 사람에 의해 승패가 결정된다. 즉, 전체 중 가장 큰 힘을 가진 사람을 가진 쪽이 승리하게 되는 것이다.
반복문을 돌며 가장 큰 수(여러 번 등장할 수 있다)와 그 큰 수가 등장한 위치를 찾는다. 만약 가장 큰 수가 한 개라면 가장 큰 수의 위치에 의해 결정된다.
가장 큰 수가 여러 개라면 첫번째로 등장한 가장 큰 수의 위치와 마지막으로 등장한 가장 큰 수의 위치에 의해 결정된다.
공의 번호가 첫번째로 등장한 가장 큰 수의 위치 전이라면 모든 큰 수가 청팀에 가게 되므로, 청팀의 승리이다.
공의 번호가 첫번째로 등장한 가장 큰 수의 위치 ~ 마지막으로 등장한 가장 큰 수의 위치 전이라면 홍팀과 청팀에 각각 적어도 하나씩은 가장 큰 수가 존재하게 되므로 비기게 된다.
공의 번호가 마지막으로 등장한 가장 큰 수의 위치 다음이라면 모든 가장 큰 수가 홍팀에 존재하게 되므로, 홍 팀의 승리이다.
따라서 첫번째로 등장한 가장 큰 수 이전에 존재하는 수의 개수(A)와 마지막으로 등장한 가장 큰 수 이후에 존재하는 수의 개수(B)의 크기 비교에 따라 확률이 결정된다.
A와 B가 같다면 홍팀과 청팀의 우승 확률이 같다. A < B라면 가장 큰 수는 홍팀에 있을 확률이 높으므로 R이 정답이 된다. A > B라면 가장 큰 수는 청팀에 있을 확률이 높으므로 B가 정답이 된다.
위 예시는 가장 큰 수가 2개 이상이면서 A<B인 경우이다. 1번을 뽑았을 경우 청팀의 승리이고, 2번과 3번을 뽑았을 경우 비긴다. 4번과 5번을 뽑았을 경우 홍팀의 승리이다. 따라서 홍팀이 이길 확률이 높다.
위 예시는 가장 큰 수가 2개 이상이면서 A = B인 경우이다. 1번을 뽑았을 경우 청팀의 승리이고, 2번, 3번, 4번을 뽑았을 경우 비긴다. 5번을 뽑았을 경우 홍팀의 승리이다. 따라서 두 팀이 이길 확률이 같다.
가장 큰 수가 2개 이상이면서 A > B인 경우이다. 1번을 뽑았을 경우 청팀의 승리이고, 2번, 3번, 4번, 5번을 뽑았을 경우 비긴다. 따라서 청팀이 이길 확률이 높다.
아래는 코드.
#include <iostream>
#include <utility>
#include <vector>
using namespace std;
int main()
{
cin.tie(NULL);
ios::sync_with_stdio(false);
int N;
cin >> N;
int* arr = new int[N];
pair<int, vector<int>> maxValues;
for (int i = 0; i < N; i++)
{
cin >> arr[i];
}
maxValues.first = arr[0];
maxValues.second.push_back(0);
for (int i = 1; i < N; i++)
{
if (arr[i] > maxValues.first)
{
maxValues.second.clear();
maxValues.first = arr[i];
maxValues.second.push_back(i);
}
else if (arr[i] == maxValues.first)
{
maxValues.second.push_back(i);
}
}
if (maxValues.second.size() == 1)
{
if (N % 2 == 0)
{
if (maxValues.second[0] + 1 <= N / 2)
{
cout << "R";
}
else
{
cout << "B";
}
}
else
{
if (maxValues.second[0] +1 == N / 2 + 1)
{
cout << "X";
}
else if (maxValues.second[0] + 1 < N / 2 + 1)
{
cout << "R";
}
else
{
cout << "B";
}
}
}
else
{
int leftCount = maxValues.second.front();
int rightCount = N - 1 - maxValues.second.back();
if (leftCount == rightCount)
{
cout << "X";
}
else if (leftCount < rightCount)
{
cout << "R";
}
else
{
cout << "B";
}
}
return 0;
}
'알고리즘 > 백준' 카테고리의 다른 글
[백준 9342] 염색체 (C++) (0) | 2024.06.30 |
---|---|
[백준 1051] 숫자 정사각형 (C++) (0) | 2024.06.29 |
[백준 29336] 월향, 비상 (C++) (0) | 2024.06.27 |
[백준 16235] 나무 재테크 (C++) (0) | 2024.06.26 |
[백준 14241] 슬라임 합치기 (C++) (0) | 2024.06.25 |