Categories: 백준

백준 2828 사과 담기 게임 (자바 Java)

백준 2828 사과 담기 게임

문제 정보

  • 문제 출처 : 백준 Baekjoon
  • 문제 번호 : 2828
  • 문제 제목 : 사과 담기 게임
  • 문제 난이도 : 실버5
  • 풀이 언어 : Java

문제

상근이는 오락실에서 바구니를 옮기는 오래된 게임을 한다. 스크린은 N칸으로 나누어져 있다. 스크린의 아래쪽에는 M칸을 차지하는 바구니가 있다. (M<N) 플레이어는 게임을 하는 중에 바구니를 왼쪽이나 오른쪽으로 이동할 수 있다. 하지만, 바구니는 스크린의 경계를 넘어가면 안 된다. 가장 처음에 바구니는 왼쪽 M칸을 차지하고 있다.

스크린의 위에서 사과 여러 개가 떨어진다. 각 사과는 N칸중 한 칸의 상단에서 떨어지기 시작하며, 스크린의 바닥에 닿을때까지 직선으로 떨어진다. 한 사과가 바닥에 닿는 즉시, 다른 사과가 떨어지기 시작한다.

바구니가 사과가 떨어지는 칸을 차지하고 있다면, 바구니는 그 사과가 바닥에 닿을 때, 사과를 담을 수 있다. 상근이는 사과를 모두 담으려고 한다. 이때, 바구니의 이동 거리의 최솟값을 구하는 프로그램을 작성하시오.

접근

반복문과 조건문을 활용해 문제를 풀었다.

풀이

  • 바구니의 시작(start)과 끝(end) 위치를 초기에 설정한다.
  • 각 사과가 떨어질 때, 바구니가 사과를 받을 수 있는 위치에 있는지 확인한다.
  • 사과가 바구니 범위 밖에 있을 경우, 바구니를 사과가 있는 위치로 이동시키고, 이동 거리를 누적하여 계산한다.
  • 전체 사과가 떨어진 후, 이동한 총 거리를 출력한다.

후기

비슷한 유형의 문제들을 더 풀어볼 계획이다.

코드

Java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        
        int N = sc.nextInt();
        int M = sc.nextInt();
        int J = sc.nextInt();
        
        int[] apples = new int[J];
        for (int i = 0; i < J; i++) {
            apples[i] = sc.nextInt();
        }

        int start = 1;
        int end = M;
        int moves = 0;
        
        for (int apple : apples) {
            if (apple < start) {

                moves += start - apple;
                start = apple;
                end = start + M - 1;
            } else if (apple > end) {

                moves += apple - end;
                end = apple;
                start = end - M + 1;
            }
        }
        
        System.out.println(moves);
    }
}
Java
suover

Recent Posts

실용적인 테스트 가이드: @Mock, @MockBean, @Spy, @SpyBean, @InjectMocks

테스트 시 의존성 주입(Dependency Injection)과 Mockito Spring 애플리케이션을 개발하다 보면, 테스트 코드에서 실제 빈(Bean)을 사용하지…

4주 ago

실용적인 테스트 가이드: Layered Architecture 레이어드 아키텍처

들어가며 스프링 기반 프로젝트에서 좋은 설계 구조와 테스트 전략은 소프트웨어 품질과 유지보수성에 직결됩니다. 최근 학습한…

1개월 ago

읽기 좋은 코드를 작성하는 사고법: 논리, 사고의 흐름과 SOLID

들어가며 코드를 작성할 때 종종 "이 로직을 어떻게 단순하고 읽기 쉽게 표현할 수 있을까?" 고민하게…

2개월 ago

읽기 좋은 코드를 작성하는 사고법: 추상과 구체

들어가며 코드를 작성하다 보면 "왜 이 코드는 한눈에 이해가 안 될까?" 하는 고민을 종종 하게…

2개월 ago

HTTP 상태코드 총정리 서버-클라이언트 간 명확한 의사소통

HTTP 상태코드란 무엇인가? HTTP 상태코드(HTTP Status Code)는 서버가 클라이언트의 요청을 처리한 결과를 수치화된 코드로 나타내는…

2개월 ago

HTTP 메서드 완벽 가이드 GET, POST, PUT, PATCH, DELETE 등 총정리

HTTP란 무엇인가? HTTP(Hypertext Transfer Protocol)는 웹에서 데이터를 주고받기 위해 사용하는 응용 계층 프로토콜입니다. 우리가 브라우저에서…

2개월 ago