Notice
Recent Posts
Recent Comments
Link
«   2025/08   »
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 29 30
31
Archives
Today
Total
관리 메뉴

코딩로그

[백준/BOJ/C++] 2484번 주사위 네개 본문

YJ/C++

[백준/BOJ/C++] 2484번 주사위 네개

Team DAON 2021. 11. 5. 14:44

[문제]

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개의 눈이 빈칸을 사이에 두고 각각 주어진다.

[출력]

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

[Source Code]

#include <stdio.h>
#include <iostream>
#include <algorithm>
#include <vector>
#include <string>
using namespace std;

int main() {
	int test, max = 0;
	cin >> test;

	for(int i = 0; i < test; i++){
		int arr[4], money = 0;
		for(int j = 0; j < 4; j++){
			int input;
			cin >> input;
			arr[j] = input;
		}
		sort(arr, arr+4);

		if(arr[0] == arr[3])
			money = 50000 + arr[0] * 5000;
		else if(arr[0] == arr[1] && arr[1] == arr[2] && arr[2] != arr[3])
			money =  10000 + arr[0] * 1000;
		else if(arr[0] != arr[1] && arr[1] == arr[2] && arr[2] == arr[3])
			money =  10000 + arr[1] * 1000;
		else if(arr[0] == arr[1] && arr[1] != arr[2] && arr[2] == arr[3])
			money = 2000 + arr[0] * 500 + arr[3] * 500;
		else if(arr[0] == arr[1] && arr[1] != arr[2] && arr[2] != arr[3])
			money = 1000 + arr[0] * 100;
		else if(arr[0] != arr[1] && arr[1] == arr[2] && arr[2] != arr[3])
			money = 1000 + arr[1] * 100;
		else if(arr[0] != arr[1] && arr[1] != arr[2] && arr[2] == arr[3])
			money = 1000 + arr[2] * 100;
		else if(arr[0] != arr[1] && arr[1] != arr[2] && arr[2] != arr[3])
			money = arr[3] * 100;

		if(max < money)
			max = money;
	}
	
	cout << max;
}

[결과 화면]