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

: ) YOUNG·2024년 2월 17일
1

알고리즘

목록 보기
319/370
post-thumbnail

프로그래머스 154538번
https://school.programmers.co.kr/learn/courses/30/lessons/154538

문제



생각하기


  • BFS를 통해서 풀 수 있는 문제이다.

    • 약간의 최적화가 필요함
  • 백준에 숨바꼭질 문제랑 매우 비슷하다.



동작



결과


코드



import java.util.*;

class Solution {
    
    public static class Number implements Comparable<Number> {
        int num;
        int count;
        
        public Number(int num, int count) {
            this.num = num;
            this.count = count;
        }
        
        @Override
        public int compareTo(Number o) {
            return count - o.count;
        }
    } // End of Number class
    
    public int solution(int x, int y, int n) {
        return BFS(x, y, n);
    } // End of solution()
    
    
    public int BFS(int x, int y, int n) {
        PriorityQueue<Number> que = new PriorityQueue<>();
        boolean[] isVisited = new boolean[y * 3];
        
        que.offer(new Number(x, 0));
        isVisited[x] = true;
       
        while(!que.isEmpty()) {
            Number cur = que.poll();
            
            if(cur.num == y) {
                return cur.count;
            } 
            
            int[] op = {cur.num + n, cur.num * 2, cur.num * 3};
            
            for(int nextNum : op) {
                if(isVisited[nextNum] || nextNum > y) continue;
                
                que.offer(new Number(nextNum, cur.count + 1));
                isVisited[nextNum] = true;
            }       
        }
        
        return -1;
    } // End of BFS()
     
} // End of Solution class

0개의 댓글