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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.
해당 문제를 봤을 때 일단 if문을 사용하여, 같은 눈이 3개인 경우, 2개인 경우, 없는 경우에 따른 분기 처리와 상금을 계산해주는 메소드를 각각 만들어 구현하고자 했다.
따라서 필드에 3개의 주사위 눈의 값을 담을 변수(dice1, dice2, dice2)를 생성하고, 메인 메소드에 if문을 3개의 값이 전부 같은 경우는 논리 연산자 &&를 사용해서, 2개의 값이 같은 경우는 논리 연산자 ||를 사용해서 분기처리를 했다.
public class Dice {
private static int dice1 = 2;
private static int dice2 = 3;
private static int dice3 = 1;
public static void main(String args[]) {
if(dice1 == dice2 && dice2 == dice3){
// 같은 눈이 3개
} else if(dice1 == dice2 || dice2 == dice3 || dice1 == dice3){
// 같은 눈이 2개
} else{
// 같은 눈이 없음
}
}
// 같은 눈이 3개
public static int triple(int a){
return 10000 + a * 1000;
}
// 같은 눈이 2개
public static int two(int a){
return 1000 + a * 100;
}
// 같은 눈이 없음
public static int one(int a){
return a * 100;
}
}
각각 분기에 실행할 상금 메서드도 구현을 했지만, 같은 눈이 2개인 경우와 같은 눈이 3개인 경우는 좀 더 로직이 더 들어가야한다는 걸 생각했다.
눈이 3개가 같으면 단순하게, 3개의 주사위 중 어떤 주사위 중 어떠한 값을 사용해도 되지만, 2개가 같으면, 어떤 주사위 2개 같은 지와, 그에 따른 눈 값으로 상금을 계산해야했고, 같지 않을 때는 주사위 중 어떤 값이 제일 큰 지를 구해야했다.
이 로직도 메서드로 구현을 할까 했지만, 하나의 메소드에 하나의 기능을 넣고 싶었고, 너무 많은 메서드를 구현하고 싶지 않아 if문을 메인 메서드에 중첩해서 사용했다.
// 1. 눈이 2개가 같을 때, 같은 눈 값 구하기
if(dice1 == dice2){
System.out.print(two(dice1));
} else if(dice2 == dice3){
System.out.print(two(dice2));
} else{
System.out.print(two(dice3));
}
// 눈이 같지 않을 때, 큰 눈 값 구하기
if(dice1 > dice2 && dice1 > dice3){
System.out.print(one(dice1));
} else if(dice2 > dice1 && dice2 > dice3){
System.out.print(one(dice2));
} else{
System.out.print(one(dice3));
}
[코드]
public class Dice {
private static int dice1 = 2;
private static int dice2 = 3;
private static int dice3 = 1;
public static void main(String args[]) {
if(dice1 == dice2 && dice2 == dice3){
System.out.print(triple(dice1));
} else if(dice1 == dice2 || dice2 == dice3 || dice1 == dice3){
if(dice1 == dice2){
System.out.print(two(dice1));
} else if(dice2 == dice3){
System.out.print(two(dice2));
} else{
System.out.print(two(dice3));
}
} else{
if(dice1 > dice2 && dice1 > dice3){
System.out.print(one(dice1));
} else if(dice2 > dice1 && dice2 > dice3){
System.out.print(one(dice2));
} else{
System.out.print(one(dice3));
}
}
}
public static int triple(int a){
return 10000 + a * 1000;
}
public static int two(int a){
return 1000 + a * 100;
}
public static int one(int a){
return a * 100;
}
}
'CS > 알고리즘 문제' 카테고리의 다른 글
[백준 - 1712] 손익 분기점 (0) | 2022.08.29 |
---|---|
[백준 - 13458] 시험 감독 (0) | 2022.08.28 |
[백준 - 4344] 평균은 넘겠지(배열 응용) (0) | 2022.08.26 |
[백준 - 1110] 새로운 수 찾기 (0) | 2022.08.26 |