[ 문제 ]
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개의 눈이 빈칸을 사이에 두고 각각 주어진다.
[ 출력 ]
첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.
[ 작성한 코드 ]
#include <stdio.h>
int main()
{
int N, number[3];
int i, j;
int max = 0, money = 0;
int result = 0;
scanf("%d", &N);
for (i = 0; i < N; i++)
{
for (j = 0; j < 3; j++)
{
scanf("%d", &number[j]);
}
if (number[0] == number[1] && number[1] == number[2])
{
money = 10000 + number[0] * 1000;
}
else if (number[0] == number[1] || number[0] == number[2])
{
money = 1000 + number[0] * 100;
}
else if (number[1] == number[2])
{
money = 1000 + number[1] * 100;
}
else
{
max = number[0];
if (number[1] > max) max = number[1];
if (number[2] > max) max = number[2];
money = max * 100;
}
if (money > result) result = money;
}
printf("%d\n", result);
return 0;
}
조건을 분기하기위한 코드가 생각보다 길고 마지막 모든 눈의 값이 다를때 최댓값을 찾는 코드를 작성하는게 핵심이라고 생각한다.
또한 마지막 result 값에 초기 money 값을 저장하고 각 줄마다 생기는 money의 값을 비교하는 조건문도 핵심이라고 생각한다.
알고리즘 분류
- 수학
- 구현
- 사칙연산
'백준 알고리즘 코딩' 카테고리의 다른 글
[C언어] 백준 3058번 짝수를 찾아라 (0) | 2025.04.27 |
---|---|
[C언어] 백준 4153번 직각삼각형 (0) | 2025.04.23 |
[C언어] 백준 2754번 학점계산 (0) | 2025.04.22 |
[C언어] 백준 26594번 ZOAC 5 (0) | 2025.04.22 |
[C언어] 백준 2566번 최댓값 (0) | 2025.04.19 |