[알고리즘] 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 |