Jaeyoung Kim
나의 개발 공부 일지
Jaeyoung Kim
전체 방문자
오늘
어제
  • 분류 전체보기 (77)
    • WIL👨‍🏫 (16)
    • 🤖Algorithm (29)
    • 🖥CS (20)
      • 기술면접대비🔎 (10)
    • ✍️개발로그 (10)

블로그 메뉴

  • 홈
  • 방명록
  • 글쓰기
  • 설정

공지사항

인기 글

태그

  • 개발로그
  • rest
  • 트랜잭션
  • 회고록
  • 데이터자료구조
  • SQLD
  • N-gram parser
  • HTTP
  • 항해99
  • querydsl
  • API
  • Java
  • WIL
  • 백준
  • sql
  • til
  • 프로그래머스
  • 자바
  • 백준2920
  • transaction

최근 댓글

최근 글

티스토리

250x250
hELLO · Designed By 정상우.
Jaeyoung Kim

나의 개발 공부 일지

[백준] 2480 주사위 세개 Java
🤖Algorithm

[백준] 2480 주사위 세개 Java

2022. 7. 30. 09:45
728x90

2480 주사위 세개


문제

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

출력

첫째 줄에 게임의 상금을 출력 한다.

예제입출력


문제풀이

if문을 사용하여 문제를 순차적으로 해결해 나갔다.

첫 번째 조건 - 3개의 주사위 눈의 숫자가 모두 동일할 때와 두 번째 조건 - 같은 눈이 2개만 나오는 경우까지는

정석대로 진행한 것 같다.

하지만 마지막 조건, 세 주사위 숫자가 모두 다를 경우에는 가장 높은 숫자 x 100을 상금으로 출력해야됐는데

이를 위해서 필요없이 긴 코드를 작성했다고 판단되었다.

 

//첫 번째 코드

import java.util.Scanner;

public class Main {
    public static void main(String[] args){
        Scanner scanner = new Scanner(System.in);

        int firstDice = scanner.nextInt();
        int secondDice = scanner.nextInt();
        int thirdDice = scanner.nextInt();

        if(firstDice == secondDice && firstDice == thirdDice){
            System.out.println(10000 +(firstDice*1000));
        } else if (firstDice == secondDice || firstDice == thirdDice) {
            System.out.println(1000 +(firstDice*100));
        } else if (secondDice == thirdDice) {
            System.out.println(1000 +(secondDice*100));
        }else{
            if(firstDice > secondDice && firstDice > thirdDice) {
                System.out.println(firstDice*100);
            } else if (secondDice > firstDice && secondDice > thirdDice) {
                System.out.println(secondDice*100);
            } else {
                System.out.println(thirdDice*100);
            }
        }


    }
}

확실히 문제 난이도에 비해 너무 장황한 코드인 것 같다.

문제는 한 번에 해결하였으나 이보다 나은 방법이 분명있을거라 생각하여 다른 사람들의 코드를 찾아보았다.

공통적으로 많이 쓴 방법 중 하나가 Math.max(함수였다. 


Math.max()

()(괄호) 안의 값 중 가장 큰 값을 꺼내주는 함수이다.

이번 문제의 경우 2번째 if문 부분을 Math.max(firstDice, Math.max(secondDice, thirdDice))로 간단히 작성 가능했다.

이를 바탕으로 코드를 재작성해보았다.


Solution.java

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        int firstDice = scanner.nextInt();
        int secondDice = scanner.nextInt();
        int thirdDice = scanner.nextInt();

        if (firstDice == secondDice && firstDice == thirdDice) {
            System.out.println(10000 + (firstDice * 1000));
        } else if (firstDice == secondDice || firstDice == thirdDice) {
            System.out.println(1000 + (firstDice * 100));
        } else if (secondDice == thirdDice) {
            System.out.println(1000 + (secondDice * 100));
        } else {
            System.out.println(Math.max(firstDice, Math.max(secondDice, thirdDice)) * 100);
        }
    }
}

 

놀랍게도 코드 길이는 첫 번째 코드에 비해 간결해졌으나 시간은 증가한 진풍경을 볼 수 있었다.

 


참고/출처

 

 

[Algorithm] 백준 2480번 - 주사위 세개

문제 링크 : https://www.acmicpc.net/problem/24801에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다. 같은 눈이 3개가 나오면 10,000원+(같은 눈)1,000원의

velog.io

 

728x90

'🤖Algorithm' 카테고리의 다른 글

[백준] 2741 N찍기 Java  (0) 2022.08.04
[백준] 15552 빠른 A+B Java  (0) 2022.08.01
[백준] 1000 A+B Java  (0) 2022.07.26
[백준] 10172 개 Java  (0) 2022.07.25
[백준] 10171 고양이 Java  (0) 2022.07.25
    '🤖Algorithm' 카테고리의 다른 글
    • [백준] 2741 N찍기 Java
    • [백준] 15552 빠른 A+B Java
    • [백준] 1000 A+B Java
    • [백준] 10172 개 Java
    Jaeyoung Kim
    Jaeyoung Kim
    보다 안정적인 코드 구현을 꿈꾸는 백엔드 개발자 지망생

    티스토리툴바