freeParksey
밥세공기
freeParksey
전체 방문자
오늘
어제
  • 분류 전체보기 (150)
    • JAVA (32)
      • 자바스터디 (21)
      • Java in action (6)
      • OOP (1)
      • test (2)
    • 알고리즘 문제 (51)
      • 백준 (49)
    • C (Atmega128) (7)
    • 인공지능 (11)
    • 운영체제 (8)
    • 디자인패턴 (5)
    • 잡다한것 (2)
    • 사용기 (3)
      • 도커 (3)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 스트림
  • 프리코스
  • 상속
  • 백트래킹
  • 재귀기초
  • 딥러닝
  • 알고리즘
  • 우테코
  • 3주차
  • dto 변환
  • 동적계획법
  • dto 변환 위치
  • generic
  • Thread #JVM #자바스터디 #
  • 백준
  • 자바
  • 그리드
  • Iterator
  • Python
  • 분류
  • 자바스터디
  • java
  • 우아한테크코스
  • 운영체제
  • 집합과 맵
  • 동작 파라미터화
  • 후기
  • Thread 동작
  • Collection
  • 백트랙킹

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
freeParksey

밥세공기

알고리즘 문제/백준

알고리즘 - 동적계획법(1463 1로 만들기)

2022. 8. 20. 22:20

문제

정수 X에 사용할 수 있는 연산은 다음과 같이 세 가지 이다.

  1. X가 3으로 나누어 떨어지면, 3으로 나눈다.
  2. X가 2로 나누어 떨어지면, 2로 나눈다.
  3. 1을 뺀다.

정수 N이 주어졌을 때, 위와 같은 연산 세 개를 적절히 사용해서 1을 만들려고 한다. 연산을 사용하는 횟수의 최솟값을 출력하시오.

입력

첫째 줄에 1보다 크거나 같고, 106보다 작거나 같은 정수 N이 주어진다.

출력

첫째 줄에 연산을 하는 횟수의 최솟값을 출력한다.

예제 입력 1 복사

2

예제 출력 1 복사

1

예제 입력 2 복사

10

예제 출력 2 복사

3

문제 요약

1을 만들어라.

이때

  • 3으로 나눠 떨어지면 3
  • 2로 나눠떨어지면 2
  • 아니면 1을 하여 

이를 수행할 최소한의 횟수는?

 

 

접근 방식

원래는 어떤 수 X부터 시작하여 1이 될때까찌 최소한으로 나누는 방식에 대한 수학적 접근 방법이 있을거라 생각하여 해당 방법으로 하려 하다가 동적계획법을 사용했다

 

지금 까지 했던 동적 계획법은 어떤 목표가 있으면 하나하나 확인하며 가는 방식이었다. 똑같이 어떤 X을 2나 3으로 나누거나 1을 빼서 1을 만드는 것을 적용했다.

 

따라서 X까지의 배열을 만들어서 하나의 값에 2와 3을 나누거나 1을 빼는 것을 통해 그 중 최소 값을 가져왔다.

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
N = int(input())
n_list = [0 for i in range(N+1)]
 
for i in range(2,N+1):
    i3 =1000000
    i2 =1000000
    i1 =1000000
    if i%3==0:
        i3 = n_list[i//3]+1
    if i%2==0:
        i2 = n_list[i//2]+1
    i1 = n_list[i-1]+1
    n_list[i] = min(i1,i2,i3)
print(n_list[N])
 

 

'알고리즘 문제 > 백준' 카테고리의 다른 글

알고리즘 - 동적계획법 (2156 포도주 시식)  (0) 2022.08.20
알고리즘 - 동적계획법 (10844 쉬운 계단 수)  (0) 2022.08.20
알고리즘 - 동적계획법 (2579 계단오르기)  (0) 2022.08.20
알고리즘 - 동적계획법(1932 정수 삼각형)  (0) 2022.08.20
알고리즘 - 동적계획법 (1149 RGB거리)  (0) 2022.08.20
    '알고리즘 문제/백준' 카테고리의 다른 글
    • 알고리즘 - 동적계획법 (2156 포도주 시식)
    • 알고리즘 - 동적계획법 (10844 쉬운 계단 수)
    • 알고리즘 - 동적계획법 (2579 계단오르기)
    • 알고리즘 - 동적계획법(1932 정수 삼각형)
    freeParksey
    freeParksey
    Github: https://github.com/parksey

    티스토리툴바