본문 바로가기
알고리즘 교육/2. 다중 반복문&배열

주사위 게임

by 곰제비 2022. 7. 21.
문제

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개의 줄에 사람들이 주사위를 던진 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.

 

출력

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

 

예제 입력

3

3 3 6

2 2 2

6 2 5

 

예제 출력

12000

 

전체 코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <iostream>
#include <vector>
#include <algorithm>
 
using namespace std;
 
int main() {
  int n, max=-1000, ans=0;
  int arr[3];
  
  cin >> n;
  for(int i=0; i<n; i++){
    for(int i=0; i<3; i++){
      cin >> arr[i];
    }
    sort(arr, arr+3);
    if(arr[0== arr[1&& arr[1== arr[2])
      ans = 10000 + arr[0* 1000;
    else if(arr[0== arr[1|| arr[1== arr[2])
      ans = 1000 + arr[1* 100;
    else
      ans = arr[2* 100;
    if(ans > max)
      max = ans;
  }
  cout << max;
  return 0;
}
cs

 

'알고리즘 교육 > 2. 다중 반복문&배열' 카테고리의 다른 글

숫자 피라미드  (0) 2022.07.21
card game  (0) 2022.07.21
소수 판별 2  (0) 2022.07.20
삼각형 출력 3  (0) 2022.07.20
삼각형 출력 1  (0) 2022.07.20