공부 흔적남기기

[JAVA] 백준 팩토리얼 0의 개수 1676 본문

코테/백준

[JAVA] 백준 팩토리얼 0의 개수 1676

65살까지 코딩 2024. 10. 21. 22:20
728x90
반응형

 

문제의 요점은 n이 커지면서 팩토리얼의 값을 변수에 저장할 수 없다는 것이다.

그럼 고민해봐야할게 어떨 때 숫자가 0으로 끝나는지 고민해봐야한다. 
차근 차근 10부터 50, 100, 150, 1500, 10000, 
0으로 끝나는 숫자들을 확인해보면 1*10, 5*10, 15*10, 15*10*10, 10*10*10*10 인것을 알 수 있다. 
즉 문제의 답은 해당 숫자에 10이 얼마나 들어가 있는지 확인해보면 된다, 
그럼 각 반복문을 돌면서 10으로 나눠 떨어진다면 10으로 계속 나눠주고 count를 해주면 될까? 



안된다. 왜냐하면 10은 2 * 5의 구성으로도 가능하기 때문이고 팩토리얼은 연속된 숫자들의 곱으로 이전 값에 영향을 받는다, 따라서 해당 숫자가 10으로 나눠 떨어질때까지 반복하고 5로 나눠질때까지 반복하고 2로 나눠질때까지 반복한 후 10으로 나눠떨어진 개수와 (5로나눠 떨어진 개수와 2로 나누어 떨어진 개수) 중 작을 것을 합하면 답을 구할 수 있다.

왜 2와 5는 나누어 떨어진 개수중 작은 것을 선택해야할까? 10은 2와 5의 구성으로 되어있는데 10이 구성되기 위해선 2와 5 둘다 필요하기 때문에 더 작은 개수를 택해야 한다.

 

import java.io.*;

public class 팩토리얼0의개수1676 {
    public static void main(String[] args) throws IOException {
        BufferedReader br =new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw =new BufferedWriter(new OutputStreamWriter(System.out));

        int n = Integer.parseInt(br.readLine());
        int tenAnswer =0;
        int twoAnswer = 0;
        int fiveAnswer = 0;
        for(int i =1; i<=n; i++){
            int temp = i;
            while (temp%10 ==0){
                temp /=10;
                tenAnswer++;
            }
            while (temp%5 ==0){
                temp /=5;
                fiveAnswer++;
            }
            while (temp%2 ==0){
                temp /=2;
                twoAnswer++;
            }
        }
        int answer = tenAnswer + Math.min(twoAnswer, fiveAnswer);
        bw.write(answer+"");
        bw.flush();
        bw.close();
        br.close();
    }
}

 

 

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

 

728x90
반응형