백준 BaekJoon 2484번: 주사위 네개 [Java] 자바

2020-10-24


문제

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

출력

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


import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class TemplateA {	
	public static void main(String[] args) throws IOException {
		
		BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));		
		int man = Integer.parseInt(bf.readLine());
		int winner = 0;
		//최대 상금 담을 변수	
		
		for(int i = 0; i < man; i++) {
		String [] arr = bf.readLine().split(" ");
				
		int max = 0;
		//같은 숫자중 최댓값 저장할 변수
		int diceNumber = 0;
		int OtherdiceNumber = 0;
		int maxDiceNumber = 0;
		
		for(int j = 0; j< arr.length -1; j++) {
			int count = 1;
			//같은 숫자 최댓값 찾을 변수	
			for(int k = j + 1; k <  arr.length; k++) {
				if(arr[j].equals(arr[k])) {
					count++;
				}
			}
	
			if(max < count) {
				max = count;
				diceNumber = Integer.parseInt(arr[j]); 
				//주사위 면을 저장할 변수	
			}else {
				if(max == 2 && count == 2) {
					OtherdiceNumber = Integer.parseInt(arr[j]); 
					//3번 조건 체크 하기 위한 식
				}			
				if(maxDiceNumber < diceNumber) {
					maxDiceNumber = diceNumber;
					//모두 다를 경우 대비한 식
					//나온 주사위 눈준 가장 큰수 저장
				}
			}
		
		}

			int sum = 0;
			//합계가 저장될 변수
			if(max == 4) {
				sum = 50000 + (diceNumber*5000);
			}else if(max == 3) {
				sum = 10000 + (diceNumber*1000);
			}else if(max == 2 && OtherdiceNumber != 0) {
				sum = 2000 + (diceNumber * 500) + (OtherdiceNumber * 500);
			}else if(max == 2) {
				sum = 1000 + (diceNumber * 100);
			}else {
				sum = maxDiceNumber * 100;
			}
			//주사위 최대변수에 대한 식
			
			if(winner < sum) {
				winner = sum;
			}
		}
		
		System.out.println(winner);
	
}
    }

 

출처 링크 : www.acmicpc.net/problem/2484

 

2484번: 주사위 네개

첫째 줄에는 참여하는 사람 수 N이 주어지고 그 다음 줄부터 N개의 줄에 사람들이 주사위를 던진 4개의 눈이 빈칸을 사이에 두고 각각 주어진다.

www.acmicpc.net