[알고리즘] 1로 만들기

2024. 2. 27. 17:01알고리즘 풀이/Java

import java.io.BufferedReader;
import java.io.InputStreamReader;

public class Main {
	public static void main(String[] args) throws Exception {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		int N = Integer.parseInt(br.readLine());
		
		int[] dp = new int[N * 3 + 1];
		for (int i = 0; i < dp.length; i++) {
			dp[i] = Integer.MAX_VALUE;
		}
		dp[1] = 0;
		for (int i = 1; i <= N; i++) {
			
			dp[i * 3] = Math.min(dp[i * 3], dp[i] + 1);
			dp[i * 2] = Math.min(dp[i * 2], dp[i] + 1);
			dp[i + 1] = Math.min(dp[i + 1], dp[i] + 1);
		}
		System.out.println(dp[N]);
	}
}

'알고리즘 풀이 > Java' 카테고리의 다른 글

[알고리즘] 파이프 옮기기 1  (1) 2024.02.28
[알고리즘][X] 외판원 순회 2  (0) 2024.02.28
[알고리즘] 최단경로  (0) 2024.02.27
[알고리즘] 낚시왕  (1) 2024.02.27
[알고리즘][X] 공주님의 정원  (0) 2024.02.26