개발자 뺚

[BAEKJOON ONLINE JUDGE] 2476번 : 주사위 게임 본문

Solution/C

[BAEKJOON ONLINE JUDGE] 2476번 : 주사위 게임

2023. 8. 15. 03:00

시간 제한 : 1 초

 

메모리 제한 : 128 MB

 

문제

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개의 눈이 빈칸을 사이에 두고 각각 주어진다. 

 

출력

첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.


#include<stdio.h>

int arr[1000][3];

int main()
{
    int n = 0;
    scanf(" %d", &n);
    
    for (int i = 0; i < n; i++)
        scanf(" %d %d %d", &arr[i][0], &arr[i][1], &arr[i][2]);
    
    int m = 0;
    int c = 0;
    for (int i = 0; i < n; i++) {
        if ((arr[i][0] == arr[i][1]) && (arr[i][0] == arr[i][2]))
            c = 10000 + arr[i][0] * 1000;
        else if ((arr[i][0] == arr[i][1]) && (arr[i][0] != arr[i][2]))
            c = 1000 + arr[i][0] * 100;
        else if ((arr[i][0] == arr[i][2]) && (arr[i][0] != arr[i][1]))
            c = 1000 + arr[i][0] * 100;
        else if ((arr[i][1] == arr[i][2]) && (arr[i][0] != arr[i][1]))
            c = 1000 + arr[i][1] * 100;
        else if (((arr[i][0] != arr[i][1]) && (arr[i][0] != arr[i][2])) && (arr[i][1] != arr[i][2])) {
            int k = (arr[i][0] <= arr[i][1] ? arr[i][1] : arr[i][0]) <= arr[i][2] ? arr[i][2] : (arr[i][0] <= arr[i][1] ? arr[i][1] : arr[i][0]);
            c = k * 100;
        }
        
        m = m <= c ? c : m;
    }
    
    printf("%d", m);
    
    return 0;
}