일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- php 프로그래밍 입문 예제
- php 프로그래밍 입문
- 백준
- C
- 자바 스프링
- php 프로그래밍 입문 3판
- 최단 경로
- 페이코 추천인코드
- php 프로그래밍 입문 솔루션
- php 프로그래밍 입문 연습문제
- php 프로그래밍 입문 문제풀이
- php
- 스프링
- 한정 분기
- 플러터
- 페이코 친구코드
- spring
- 페이코 초대코드
- 자바
- JAVA SPRING
- Java
- 파이썬
- SWEA
- C언어
- 페이코 추천인
- Flutter
- programmers
- 플러터 개발환경 설정
- 배열
- php 프로그래밍
Archives
- Today
- Total
01-23 02:33
ImJay
[BOJ/Java] 1463. 1로 만들기 본문
반응형
[BOJ/Java] 1463. 1로 만들기
문제 해석
이 문제는 주어진 수 𝑋를 1로 만드는 데 필요한 최소 연산 횟수를 찾는다. 연산은 다음 세 가지 중 하나를 선택할 수 있다:
- 𝑋가 3으로 나누어 떨어지면, 3으로 나눈다.
- 𝑋가 2로 나누어 떨어지면, 2로 나눈다.
- 𝑋에서 1을 뺀다.
풀이 과정
이 문제는 동적 계획법(Dynamic Programming, DP)을 사용하여 해결할 수 있다. 각 숫자 𝑖에 대하여, 𝑖를 1로 만드는 최소 연산 횟수를 dp[i] 배열에 저장한다. 점화식은 다음과 같다:
- 𝑑𝑝[𝑖]=𝑑𝑝[𝑖−1]+1
- 𝑑𝑝[𝑖]=min(𝑑𝑝[𝑖],𝑑𝑝[𝑖/3]+1) (만약 𝑖%3==0)
- 𝑑𝑝[𝑖]=min(𝑑𝑝[𝑖],𝑑𝑝[𝑖/2]+1) (만약 𝑖%2==0)
코드
package edu.ssafy.im.BOJ.Silver.S3.No1463;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
public class Main {
public static void main(String[] args) throws NumberFormatException, IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringBuilder sb = new StringBuilder();
int X = Integer.parseInt(br.readLine());
int[] dp = new int[X+1];
dp[1] = 0; // 1을 1로 만드는 데 필요한 최소 연산 횟수는 0
for (int i = 2; i <= X; i++) {
dp[i] = dp[i-1] + 1; // 연산 3: 1을 빼는 경우
if (i % 3 == 0) dp[i] = Math.min(dp[i], dp[i/3] + 1); // 연산 1: 3으로 나누는 경우
if (i % 2 == 0) dp[i] = Math.min(dp[i], dp[i/2] + 1); // 연산 2: 2로 나누는 경우
}
sb.append(dp[X]);
bw.write(sb.toString());
bw.flush();
bw.close();
}
}
시간 복잡도 분석
이 코드의 시간 복잡도는 𝑂(𝑁)이다. 여기서 𝑁은 입력으로 주어진 𝑋의 값이다. 각 숫자에 대해 세 가지 연산 중 최소 값을 계산하기 때문에, 동적 계획법을 통해 효율적으로 문제를 해결한다.
느낀점
동적 계획법을 사용하여 주어진 문제를 체계적으로 분해하고 해결하는 방법을 배우고, 이를 통해 문제를 해결하는 것은 매우 유익한 경험이었다. 본 문제처럼 간단한 점화식을 통해 복잡한 문제를 해결할 수 있다는 것을 알게 되었다.
반응형
'알고리즘 > BOJ - Java' 카테고리의 다른 글
[BOJ/Java] 11403. 경로 찾기 (1) | 2024.04.21 |
---|---|
[BOJ/Java] 15652. N과 M (4) (1) | 2024.04.21 |
[BOJ/Java] 1753. 최단경로 (0) | 2024.04.21 |
[BOJ/Java] 11562. 백양로 브레이크 (0) | 2024.04.21 |
[BOJ/Java] 2457. 공주님의 정원 (0) | 2024.04.21 |
Comments