Sablog Models/알고리즘

2010 정보올림피아드 지역본선 고등부 문제 Review (1)

어­리 2011. 5. 2. 11:21
블로그에 떡밥이 없어서 1년이 거의 다 된 소재를 지금이라도 뿌리기로 했다.
이렇게라도 활동을 시작하면 뭔가 소재가 생각나지 않을까... (도망)

주사위 네개

1에서부터 6까지의 눈을 가진 4개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.

규칙(1) 같은 눈이 4개가 나오면 50,000원+(같은 눈)*5,000원의 상금을 받게 된다.

규칙(2) 같은 눈이 3개만 나오면 10,000원+(3개가 나온 눈)*1,000원의 상금을 받게 된다.

규칙(3) 같은 눈이 2개씩 두 쌍이 나오는 경우에는 2,000원+(2개가 나온 눈)*500원+(또 다른 2개가 나온 눈)*500원의 상금을 받게 된다.

규칙(4) 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)*100원의 상금을 받게 된다.

규칙(5) 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)*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)명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램을 작성하시오.
   실행파일의 이름은 DICE4.EXE로 하고, 프로그램의 실행시간은 1초를 넘을 수 없다. 부분 점수는 없다.

입력 형식
   입력 파일의 이름은 INPUT.TXT이다. 첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 4개의 눈이 빈칸을 사이에 두고 각각 주어진다.

출력 형식
   출력 파일의 이름은 OUTPUT.TXT이다. 첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.

입력과 출력의 예

입력(INPUT.TXT)
4
3 3 3 3
3 3 6 3
2 2 6 6
6 2 1 5
출력(OUTPUT.TXT)
65000
맞춤법에 의하면 '주사위 네 개'입니다. 관형어와 체언은 떼어 씁니다. 맞춤법 틀리는 정올

간단한 다중 조건식으로 해결할 수 있다.
#include <stdio.h>

int main()
{
    int n;
    int a, b, c, d;
    int pt, pt_max = 0;
    FILE *fp;
    fp = fopen("INPUT.TXT", "r");
    fflush(stdout);
    fscanf(fp, "%d", &n);
    while (n-- > 0) {
        fflush(stdout);
        fscanf(fp, "%d %d %d %d", &a, &b, &c, &d);
        if (a == b && b == c && c == d)
            pt = 50000 + a * 5000;
        else if ((a == b && b == c) || (a == b && b == d) || (a == c && c == d))
            pt = 10000 + a * 1000;
        else if ((a == b && c == d) || (a == c && b == d))
            pt = 2000 + a * 500 + d * 500;
        else if (a == d && b == c)
            pt = 2000 + a * 500 + b * 500;
        else if (a == b || a == c || a == d)
            pt = 1000 + a * 100;
        else if (b == c || b == d)
            pt = 1000 + b * 100;
        else if (c == d)
            pt = 1000 + c * 100;
        else if (a > b && a > c && a > d)
            pt = a * 100;
        else if (b > c && b > d)
            pt = b * 100;
        else if (c > d)
            pt = c * 100;
        else
            pt = d * 100;
        if (pt > pt_max) pt_max = pt;
    }
    fclose(fp);
    fp = fopen("OUTPUT.TXT", "w");
    fprintf(fp, "%d", pt_max);
    fclose(fp);
    return 0;
}

나는 당시에 시험장에서 조건문 분기 중복을 없애려다 1시간을 버렸다.