본문 바로가기

정보올림피아드&알고리즘

주사위 게임

주사위 게임

문제

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