Park DJ
dj0998
Park DJ
전체 방문자
오늘
어제
  • 분류 전체보기 (363)
    • 백준 (363)

공지사항

인기 글

태그

  • 백준 2591
  • 백준 1064
  • 백준 1495
  • 백준 1011
  • 백준 6550
  • 백준 16194
  • 백준 3049
  • 백준 3135
  • 백준 1531
  • 백준 16926
  • 백준
  • 백준 2225
  • 백준 4659
  • 백준 12871
  • 자바
  • 백준 14582
  • 백준 15961
  • 백준 10709
  • 백준 15655
  • 백준 15312
  • 백준 12605
  • 백준 2467
  • 백준 7662
  • 백준 8892
  • 백준 1914
  • 백준 7567
  • Java
  • 백준 24039
  • 백준 2343
  • 백준 1747
hELLO · Designed By 정상우.
Park DJ

dj0998

백준 12852 1로 만들기 2(Java)
백준

백준 12852 1로 만들기 2(Java)

2023. 2. 19. 21:48

https://www.acmicpc.net/problem/12852

 

12852번: 1로 만들기 2

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

www.acmicpc.net


 

Java 코드

 


import java.util.Scanner;

public class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    StringBuilder sb = new StringBuilder();

    int n = sc.nextInt();
    
    int[] arr = new int[n + 1];
    int[] num = new int[n + 1];

    arr[1] = 0;
  
    for(int i = 2; i <= n; i++) {
      arr[i] = arr[i - 1] + 1;
      num[i] = i - 1;
      if(i % 2 == 0 && arr[i / 2] + 1 < arr[i]) {
        arr[i] = arr[i / 2] + 1;
        num[i] = i / 2;
      }
      
      if(i % 3 == 0 && arr[i / 3] + 1 < arr[i]) {
        arr[i] = arr[i / 3] + 1;
        num[i] = i / 3;
      }
    }
    
    sb.append(arr[n]+"\n");

    while(n > 0) {
      sb.append(n+" ");
      n = num[n];
    }
    System.out.println(sb);
  }
}

'백준' 카테고리의 다른 글

백준 14490 백대열(Java)  (0) 2023.02.19
백준 16435 스네이크버드(Java)  (0) 2023.02.19
백준 1325 효율적인 해킹(Java)  (0) 2023.02.19
백준 1926 그림(Java)  (0) 2023.02.19
백준 2529 부등호(Java)  (0) 2023.02.19
    '백준' 카테고리의 다른 글
    • 백준 14490 백대열(Java)
    • 백준 16435 스네이크버드(Java)
    • 백준 1325 효율적인 해킹(Java)
    • 백준 1926 그림(Java)
    Park DJ
    Park DJ

    티스토리툴바