# 문제 출제 사이트
https://www.acmicpc.net/problem/2480
# 문제
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원을 상금으로 받게 된다.
3개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.
# 입력
첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.
# 출력
첫째 줄에 게임의 상금을 출력 한다.
# 제출한 소스코드
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String[] inputStrArr = sc.nextLine().split(" ");
int result = 0;
for(int i = 0; i < inputStrArr.length; i++) {
int sameNum = 0;
int tempNum = Integer.parseInt(inputStrArr[i]);
int maxNum = 0;
for(int j = 0; j < inputStrArr.length; j++) {
int jNum = Integer.parseInt(inputStrArr[j]);
if(maxNum < jNum) {
maxNum = jNum;
}
if(tempNum == jNum) {
sameNum++;
}
}
if(sameNum == 3) {
result = 10000 + tempNum * 1000;
break;
} else if(sameNum == 2) {
result = 1000 + tempNum * 100;
break;
} else {
result = maxNum * 100;
}
}
System.out.println(result);
}
}
첫 제출한 코드가 메인 함수에 담겨있어서 한번 나눠봤습니다.
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String[] inputStrArr = sc.nextLine().split(" ");
CalcDice calcDice = new CalcDice();
int result = calcDice.calcMethod(inputStrArr);
System.out.println(result);
}
}
class CalcDice {
public int calcMethod(String[] inputStrArr) {
int result = 0;
int[] intArr = strArrayToIntArray(inputStrArr);
for(int i = 0; i < intArr.length; i++) {
int sameNum = 0;
int tempNum = intArr[i];
int maxNum = 0;
for(int j = 0; j < intArr.length; j++) {
int jNum = intArr[j];
if(maxNum < jNum)
maxNum = jNum;
if(tempNum == jNum)
sameNum++;
}
if(sameNum == 3) {
result = 10000 + tempNum * 1000;
break;
} else if(sameNum == 2) {
result = 1000 + tempNum * 100;
break;
} else {
result = maxNum * 100;
}
}
return result;
}
private int[] strArrayToIntArray(String[] inputStrArr) {
int strArrLength = inputStrArr.length;
int[] intArr = new int[strArrLength];
for(int i = 0; i < strArrLength; i++) {
intArr[i] = Integer.parseInt(inputStrArr[i]);
}
return intArr;
}
}
위와 같이 클래스를 만들고 각각 메소드로 나눠 봤습니다.
반응형