백준 Baekjoon 2484번 주사위 네개 - JAVA

Jaeho Kim·2022년 4월 13일
0

코딩테스트

목록 보기
22/110

문제
1에서부터 6까지의 눈을 가진 4개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.
같은 눈이 4개가 나오면 50,000원+(같은 눈)×5,000원의 상금을 받게 된다.
같은 눈이 3개만 나오면 10,000원+(3개가 나온 눈)×1,000원의 상금을 받게 된다.
같은 눈이 2개씩 두 쌍이 나오는 경우에는 2,000원+(2개가 나온 눈)×500원+(또 다른 2개가 나온 눈)×500원의 상금을 받게 된다.
같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×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개의 눈이 빈칸을 사이에 두고 각각 주어진다.

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

예제 입력 1

4
3 3 3 3
3 3 6 3
2 2 6 6
6 2 1 5

예제 출력 1

65000
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {

	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

		int N = Integer.parseInt(br.readLine());

		int reward = 0;
		int bestReward = 0;
		for (int i = 0; i < N; i++) {
			StringTokenizer st = new StringTokenizer(br.readLine());
			int maxDice = 0; // 최대 중복 주사위
			int secondDice = 0; // 최대 중복 주사위 2(중복건수가 2로 동일할시)
			int count = 0; // 중복 건수

			int[] dice = new int[4];
			for (int j = 0; j < 4; j++) {
				dice[j] = Integer.parseInt(st.nextToken());

				for (int num = 1; num <= 6; num++) { // 1부터 6까지 반복한다.
					int tempCount = 0;
					for (int l = 0; l < dice.length; l++) { // 현재 저장된 4개 주사위를 가져온다.

						if (num == dice[l]) { // 현재 수와 같은 주사위가 있을시 + 1
							tempCount = tempCount + 1;
						}
					}
					if (count < tempCount && maxDice < num) { // 더 큰 주사위 갯수가 많을시
						count = tempCount;
						maxDice = num;
						secondDice = 0;
					} else if (count == tempCount && maxDice < num && count == 1) { // 중복이 없을시 가장 큰 주사위
						maxDice = num;
					} else if (count == tempCount) { // 2개 2쌍
						secondDice = num;
					}
				}

				if (count == 4) { // 상금 계산
					reward = 50000 + maxDice * 5000;
				} else if (count == 3) {
					reward = 10000 + maxDice * 1000;
				} else if (count > 1 && secondDice > 0) {
					reward = 2000 + maxDice * 500 + secondDice * 500;
				} else if (count == 2) {
					reward = 1000 + maxDice * 100;
				} else if (count == 1) {
					reward = maxDice * 100;
				}

				if (reward > bestReward)
					bestReward = reward;
			}
			System.out.println(bestReward);
			br.close();
		}
	}
}
  • 설명
profile
Hello, World!

0개의 댓글