본문 바로가기
Algorithm/코드업

[Codeup] 4691 : 주사위 네 개 (C언어)

by 이호수 2024. 12. 1.

문제

문제 설명   

문제1) 주사위 네개(고등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)명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램을 작성하시오.

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

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


입력 예시   예시 복사

4

3 3 3 3

3 3 6 3

2 2 6 6
6 2 1 5

 

출력 예시

65000

 

 

풀이

#include <stdio.h>

int main()
{
	// 변수 선언. tt:1~6주사위 나온 횟수, rwd:상금, mx:상금 최댓값, f:중복해서 나온 값
    int n, i, j, rwd, tt[7]={0}, a, b, c, d, mx=-1, f;
    scanf("%d", &n);
    for(i=0;i<n;i++){
        scanf("%d %d %d %d", &a, &b, &c, &d);
        
        // 각 주사위 수(1~6)의 개수 세주기
        for(j=1;j<=6;j++){
            if(j==a) tt[j]++;
            if(j==b) tt[j]++;
            if(j==c) tt[j]++;
            if(j==d) tt[j]++;
        }
        
        f=0; // 중복된 값이 없을 때, f를 0으로 계산
        // 점수 계산
        for(j=1;j<=6;j++){
            if(tt[j]==4) {
            	rwd = 50000 + j*5000;
                break;
            }
            else if(tt[j]==3) {
            	rwd = 10000+j*1000; 
                break;
            }
            else if(tt[j]==2 && f!=0) {
            	rwd = 2000+ j*500 + f*500; 
                break;
            }
            else if(tt[j]==2 && f==0) {
            	f = j; 
                rwd = 1000+j*100;
            } 
            else if(tt[j]==1 && f==0) {
            	rwd = j*100;
            }
        }
        // 최댓값 계산
        if(rwd>mx) mx = rwd;
 
        // 초기화
        for(j=1;j<=6;j++) tt[j]=0;
    }
    printf("%d", mx);
    
    return 0;
}