2484번 : 주사위 네개
문제 )
1에서부터 6까지의 눈을 가진 4개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.
- 같은 눈이 4개가 나오면 50,000원+(같은 눈)×5,000원의 상금을 받게 된다.
- 같은 눈이 3개만 나오면 10,000원+(3개가 나온 눈)×1,000원의 상금을 받게 된다.
- 같은 눈이 2개씩 두 쌍이 나오는 경우에는 2,000원+(2개가 나온 눈)×500원+(또 다른 2개가 나온 눈)×500원의 상금을 받게 된다.
- 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
- 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×100원의 상금을 받게 된다.
예를 들어, 4개의 눈이 3, 3, 3, 3으로 주어지면 50,000+3×5,000으로 계산되어 65,000원의 상금을 받게 된다. 4개의 눈이 3, 3, 6, 3으로 주어지면 상금은 10,000+3×1,000으로 계산되어 13,000원을 받게 된다. 또 4개의 눈이 2, 2, 6, 6으로 주어지면 2,000+2×500+6×500으로 계산되어 6,000원을 받게 된다. 4개의 눈이 6, 2, 1, 6으로 주어지면 1,000+6×100으로 계산되어 1,600원을 받게 된다. 4개의 눈이 6, 2, 1, 5로 주어지면 그 중 가장 큰 값이 6이므로 6×100으로 계산되어 600원을 상금으로 받게 된다.
N(1 ≤ N ≤ 1,000)명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램을 작성하시오.
입력 :
첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 4개의 눈이 빈칸을 사이에 두고 각각 주어진다.
출력 :
첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.
풀이)
쉽게 풀 수 있는거 같은데,
처음에 생각을 잘못 했는지 생각보다 많이 꼬여 어렵게 푼 것 같다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
#include <iostream>
#include <algorithm>
using namespace std;
int cal_money(int die, int dices[], bool flag) {
int dice_spot;
int temp = 0;
for (int i = 1; i < 7; i++) {
if(dices[i] == die) {
dice_spot = i;
}
// 3번 케이스
if (dices[i] == 2 && flag == 1) {
temp += i * 500;
}
// 5번 케이스
if (dices[i] == 1 && die == 1) {
temp = temp < dice_spot * 100 ? dice_spot * 100 : temp;
}
}
// 1번 케이스
if (die == 4) {
return 50000 + dice_spot * 5000;
}
// 2번 케이스
else if (die == 3) {
return 10000 + dice_spot * 1000;
}
// 3번 케이스
else if (die == 2 && flag) {
return 2000 + temp;
}
// 4번 케이스
else if (die == 2) {
return 1000 + dice_spot * 100;
}
// 5번 케이스
else if (die == 1) {
return temp;
}
}
int main()
{
int n;
cin >> n;
// winner => 가장 많은 상금을 받은 사람의 상금
int winner = 0;
for (int i = 0; i < n; i++) {
int dices[7] = { 0 };
for (int j = 0; j < 4; j++) {
int a;
cin >> a;
dices[a]++;
}
// 최대 몇개가 겹쳤는가?
int die = *max_element(dices, dices + 7);
// 2개 2개 쌍을 이뤘는가?
int multi_count = count(dices, dices + 7, 2);
winner = winner < cal_money(die, dices, multi_count == 2) ? cal_money(die, dices, multi_count == 2) : winner;
}
cout << winner << endl;
return 0;
}
|
cs |
출처 : https://www.acmicpc.net/problem/2484
2484번: 주사위 네개
첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 4개의 눈이 빈칸을 사이에 두고 각각 주어진다.
www.acmicpc.net
'Develop > 백준 (Cpp)' 카테고리의 다른 글
[백준] 3059번 : 등장하지 않는 문자의 합 (C++) (2) | 2023.02.04 |
---|---|
[백준] 2789번 : 유학 금지 (C++) (1) | 2023.02.04 |
[백준] 2495번 : 연속구간 (C++) (1) | 2023.02.04 |
[백준] 2720번 : 세탁소 사장 동혁 (C++) (1) | 2023.02.04 |
[백준] 2609번 : 최대공약수와 최소공배수 (C++) (0) | 2023.02.04 |