Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 다익스트라 알고리즘
- 다익스트라
- 호스팅이란?
- Proxy Server
- 동기화
- 싸피 합격
- Proxy
- 뮤텍스란?
- 뮤텍스
- 웹 호스팅
- 클라우드 서버
- 세마포어와 뮤텍스
- 세마포어란?
- 플로이드 워셜
- SSAFY
- 삼성 청년 SW 아카데미
- 서버 호스팅
- Dijkstra Algorithm
- 호스팅
- 세마포어와 뮤텍스의 차이
- 싸피
- 플로이드 와샬
- Synchronization
- 프록시서버
- 싸피 면접 후기
- 세마포어
- 최단 경로
- floyd-warshall
- 프록시
Archives
- Today
- Total
어제의 나보다 성장한 오늘의 나
[백준][BOJ-1463][자바] 1로 만들기 본문
import java.io.*;
import java.util.*;
public class Main {
static int min = Integer.MAX_VALUE;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine());
int[] dp = new int[1000001];
dp[2] = 1;
dp[3] = 1;
for(int i=4; i<=n; i++) {
dp[i] = dp[i-1] +1;
if(i % 3 ==0) {
if( dp[i / 3] < dp[i]) {
dp[i] = dp[i / 3] +1;
}
}
if( i % 2 == 0) {
if( dp[i/2] <dp[i]) {
dp[i] = dp[i/2]+1;
}
}
}
System.out.println(dp[n]);
}
}
정리
먼저 메모리제이션으로 풀어봤습니다. 문제에 주어진 대로 연산을 사용하는 횟수의 최솟값을 구하기 때문에 최대한 -1을 적게 하면 좋습니다.
따라서 2와 3은 최소 1번 수행에 4부터 3번 조건으로 dp[i-1] +1의 최솟값을 가지고 시작합니다.
하지만 4는 2로 나누어 지고, 그러면 2로 나눈 dp[2] 보다 한 번 더 실행하게 됩니다. 따라서 dp[4] = 2;
이번에는 5를 봅시다. 3번 조건에 의해 4의 최소 연산의 +1이을 최소값을 가지고 되고 조건 1과 조건 2가 맞지 않기 때문에 5는 3번의 연산이 이루어집니다. dp[5] = 3;
마지막으로 6을 보자 3번 조건에 의해 5보다 +1한 값인 dp[6] = 4 조건으로 시작합니다. 1번을 만족하고 dp[2]와 비교했을 때 dp[2]가 값이 더 작다 따라서 dp[2] +1; 을 해주면 dp[6] = 2가 됩니다.
위를 n번이하 까지 반복하면 각 숫자는 최소 연산을 가지게 됩니다.
import java.io.*;
import java.util.*;
public class Main {
static int min = Integer.MAX_VALUE;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
dfs(0,Integer.parseInt(br.readLine()));
System.out.println(min);
}
public static void dfs(int cnt, int num) {
if(min < cnt) return;
if(num == 0) {
min = Math.min(min, cnt-1);
return;
}
if(num%3 == 0) dfs(cnt+1, num/3);
if(num%2 == 0) dfs(cnt+1, num/2);
dfs(cnt+1, num-1);
}
}
다음은 재귀형태로 풀어봤습니다.
먼저 if문으로 3이나 2로 나누어지면 재귀를 돌려주고 -1은 무조건 재귀를 돌게 했습니다.
여기서 num이 0이라는 말은 연산이 끝났다는 말이고 최소 연산을 비교해서 저장합니다.
가지치기로 최소 연산 횟수보다 연산 횟수가 많아진다면 더 이상 연산할 필요가 없기 때문에 return 해주었습니다.
'알고리즘 > 백준(BOJ)' 카테고리의 다른 글
[백준][BOJ-2583][자바] 영역 구하기 (0) | 2021.05.11 |
---|---|
[백준][BOJ-2631][자바] 줄세우기 (0) | 2021.05.09 |
[백준][BOJ-3980][자바] 선발 명단 (0) | 2021.04.27 |
[백준][BOJ-3078][자바] 좋은 친구 (0) | 2021.04.22 |
[백준][BOJ-1725][자바] 히스토그램 (0) | 2021.04.21 |
Comments