11653 소인수분해

JH·2022년 12월 15일

Baekjoon (Java)

목록 보기
22/25

📘 Question

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

문제

정수 N이 주어졌을 때, 소인수분해하는 프로그램을 작성하시오.

입력

첫째 줄에 정수 N (1 ≤ N ≤ 10,000,000)이 주어진다.

출력

N의 소인수분해 결과를 한 줄에 하나씩 오름차순으로 출력한다. N이 1인 경우 아무것도 출력하지 않는다.

✍️ Answer

생각

  1. num에서 2부터 나누고 인수 출력하기
  2. 인수가 아니면 1 더하기
  3. num이 1이상일 때까지 반복
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int num = sc.nextInt();
        int k = 2;

        while(num>1){
            if (num % k == 0) {
                num /= k;
                System.out.println(k);
            } else {
                k++;
            }
        }
    }
}
profile
매일 한 문제씩 풀기

0개의 댓글