누룽지맛치킨
어미새의 개발일지
누룽지맛치킨
전체 방문자
오늘
어제
  • 분류 전체보기 (86)
    • 코틀린 (8)
    • 안드로이드 (5)
      • 디자인 (2)
      • 개발 (2)
      • 도구 (1)
    • 피그마 (1)
    • 대외활동 (0)
    • 프로젝트 (0)
    • 백준 (55)
      • JAVA (55)
    • 알고리즘 (3)
    • 클라우드 (5)
    • 스터디 (2)
      • 코테 (2)
    • 자료구조 (5)
    • 컴퓨터 기술 (1)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 코틀린
  • 클라우드
  • 알고리즘 조합
  • 클라우드 컴퓨팅
  • 백준 자바 2559번
  • Room version 올리기
  • 백준 자바 수열
  • 안드로이드 디자인
  • 자료구조
  • 코틀린 runBlocking
  • 안드로이드
  • 백준 자바 정렬
  • 백준 자바 다이나믹 프로그래밍
  • 백준 자바 벌집
  • 백준 자바
  • 백준 자바 2292번
  • 코틀린 인 액션
  • 백준 자바 누적합
  • 자바 Priority Queue
  • Room Migration

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
누룽지맛치킨
백준/JAVA

[백준/JAVA] 2480번 주사위 세개

백준/JAVA

[백준/JAVA] 2480번 주사위 세개

2023. 1. 16. 15:24
  • 조건에 따라 상금을 계산하는 문제
    https://www.acmicpc.net/problem/2480

1. 문제

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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.

2. 문제 접근

  • 조건문을 사용하는 일반적인 방식대신 배열을 사용하여 문제에 접근 시도
  • 주사위 눈에 해당하는 인데스의 값을 1씩 더한다.
  • 인덱스 1부터 6까지 돌면서 해당 인덱스의 값이 3이면 같은 눈이 3개 나온 상황, 값이 2가 나오면 같은 눈이 2개 나온 상황, 그 외에는 모두 다른 눈이 나오는 상황으로 간주.

3. 코드

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

public class Main {
    public static void main(String[] args) throws IOException{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st = new StringTokenizer(br.readLine());
        int prize=0;

        int dice[] = new int[7];
        for(int i=0;i<3;i++) {
            dice[Integer.parseInt(st.nextToken())]++;
        }
        for(int i=1;i<7;i++) {
            if(dice[i]==3) {
                prize = 10000 + i*1000;
                break;
            }
            if(dice[i]==2) {
                prize = 1000 + i*100;
                break;
            }
            if(dice[i]==1) {
                prize = 100 * i;
            }
        }
        System.out.println(prize);
    }
}

'백준 > JAVA' 카테고리의 다른 글

[백준/JAVA] 단계별로 풀어보기(2단계) 코드 모음  (0) 2023.01.17
[백준/JAVA] 단계별로 풀어보기(1단계) 코드 모음  (0) 2023.01.16
[백준/JAVA] 11021번 A+B-7  (0) 2023.01.16
[백준/JAVA] 15552번 빠른 A+B  (0) 2023.01.16
[백준/JAVA] 1008번 A/B  (0) 2023.01.16
    '백준/JAVA' 카테고리의 다른 글
    • [백준/JAVA] 단계별로 풀어보기(1단계) 코드 모음
    • [백준/JAVA] 11021번 A+B-7
    • [백준/JAVA] 15552번 빠른 A+B
    • [백준/JAVA] 1008번 A/B
    누룽지맛치킨
    누룽지맛치킨

    티스토리툴바

    단축키

    내 블로그

    내 블로그 - 관리자 홈 전환
    Q
    Q
    새 글 쓰기
    W
    W

    블로그 게시글

    글 수정 (권한 있는 경우)
    E
    E
    댓글 영역으로 이동
    C
    C

    모든 영역

    이 페이지의 URL 복사
    S
    S
    맨 위로 이동
    T
    T
    티스토리 홈 이동
    H
    H
    단축키 안내
    Shift + /
    ⇧ + /

    * 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.