문제
1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.
- 같은 눈이 3개가 나오면 10,000원+(같은 눈)*1,000원의 상금을 받게 된다.
- 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)*100원의 상금을 받게 된다.
- 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)*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개의 눈이 빈칸을 사이에 두고 각각 주어진다.
출력
첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.
예제 입력 1
3 3 3 6 2 2 2 6 2 5 |
예제 출력 1
12000 |
더보기
Solution
#include<stdio.h>
int main(void)
{
int N, max_price=0;
scanf("%d", &N);
for(int i=0;i<N;i++)
{
int dice[3], price;
scanf("%d %d %d", &dice[0], &dice[1], &dice[2]);
for(int j=0;j<2;j++)
for(int k=j+1;k<3;k++)
if(dice[j]>dice[k])
{
int temp=dice[j];
dice[j]=dice[k];
dice[k]=temp;
}
price=dice[0]==dice[2]?(10000+1000*dice[2]):dice[0]==dice[1]||dice[1]==dice[2]?(1000+100*dice[1]):100*dice[2];
max_price=price>max_price?price:max_price;
}
printf("%d\n", max_price);
return 0;
}
728x90
'백준 알고리즘' 카테고리의 다른 글
<백준 알고리즘> 11006번: 남욱이의 닭장 (0) | 2020.07.24 |
---|---|
<백준 알고리즘> 2490번: 윷놀이 (0) | 2020.07.23 |
<백준 알고리즘> 11047번: 동전 0 (0) | 2020.07.23 |
<백준 알고리즘> 12790번: Mini Fantasy War (0) | 2020.07.23 |
<백준 알고리즘> 16673번: 고려대학교에는 공식 와인이 있다 (0) | 2020.07.23 |