Algorithm/Programmers Java

Java 프로그래머스 숫자 변환하기

제우제우 2024. 2. 28. 21:19

https://school.programmers.co.kr/learn/courses/30/lessons/154538

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

문제 분류 : 코딩테스트 연습 > 연습문제 > 숫자 변환하기

난이도 : 2

 

정답 코드

import java.util.*;
class Solution {
    public int solution(int x, int y, int n) {
        int [] DP = new int[1000001]; 
        Arrays.fill(DP, 1000001);
        DP[x] = 0;
        for(int i = x + 1; i <= y ; i++){
            
            if(i % 2 == 0){
                DP[i] = Math.min(DP[i], DP[i/2] + 1);
            }
            if(i % 3 == 0){
                DP[i] = Math.min(DP[i], DP[i/3] + 1);
            }
            if(i - n >= x){
                DP[i] = Math.min(DP[i], DP[i - n] + 1);
            }
            
        }
        if(DP[y] == 1000001) return -1;
        return DP[y];
    }
}