주사위 게임
문제
1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.
규칙(1) 같은 눈이 3개가 나오면 10,000원+(같은 눈)*1,000원의 상금을 받게 된다.
규칙(2) 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)*100원의 상금을 받게 된다.
규칙(3) 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)*100원의 상금을 받게 된다.
예를 들어, 3개의 눈 3, 3, 6이 주어지면 상금은 1,000+3*100으로 계산되어 1,300원을 받게 된다.
또 3개의 눈이 2, 2, 2로 주어지면 10,000+2*1,000 으로 계산되어 12,000원을 받게 된다.
3개의 눈이 6, 2, 5로 주어지면 그 중 가장 큰 값이 6이므로 6*100으로 계산되어 600원을 상금으로 받게 된다.
N(2≤N≤1,000) 명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램을 작성하시오.
입력형식
첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.
출력형식
첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.
입력 예
3
3 3 6
2 2 2
6 2 5
출력 예
12000
소스코드
더보기
#include <stdio.h>
struct dice{
int num[7];
int point[3];
} play[1000];
int n, su1, su2, su3;
int count1, count2, count3, i, j;
int a1[1000], a2[1000], a3[1000];
void manwon()
{
int k, max = -1;
for (i = 0; i < count3; i++)
{
k = a3[i];
if (max < play[k].point[0])
max = play[k].point[0];
}
printf("%d", 10000 + max * 1000);
}
void hanwon()
{
int k, max = -1, point = 0;
for (i = 0; i < count2; i++)
{
k = a2[i];
for (j = 1; j <= 6; j++) {
if (play[k].num[j] == 2)
point = j;
if (max < point)
max = point;
}
}
printf("%d", 1000 + max * 100);
}
int main()
{
int cnt = 0, max = -1;
scanf("%d", &n);
for (i = 0; i < n; i++)
{
scanf("%d %d %d", &su1, &su2, &su3);
play[i].num[su1]++;
play[i].num[su2]++;
play[i].num[su3]++;
cnt = 0;
for (j = 1; j <= 6; j++) {
if (play[i].num[0] < play[i].num[j]) {
play[i].num[0] = play[i].num[j];
play[i].point[cnt++] = j;
}
}
if (play[i].num[0] == 3)
a3[count3++] = i;
else if (play[i].num[0] == 2)
a2[count2++] = i;
}
if (count3 >= 1)
manwon();
else if (count2 >= 1)
hanwon();
else
{
for (i = 0; i < n; i++) {
for (j = 1; j <= 6; j++) {
if (play[i].num[j] == 1)
cnt = j;
if (max < cnt)
max = cnt;
}
}
printf("%d", max * 100);
}
return 0;
}
'정보올림피아드&알고리즘' 카테고리의 다른 글
싸이클 - 2012년 (0) | 2021.12.23 |
---|---|
나는 학급회장이다.(투표) (0) | 2021.12.23 |
수열 (0) | 2021.12.08 |
떡 먹는 호랑이 (0) | 2021.12.08 |
색종이(초) (0) | 2021.12.08 |