#문제

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

 

1676번: 팩토리얼 0의 개수

N!에서 뒤에서부터 처음 0이 아닌 숫자가 나올 때까지 0의 개수를 구하는 프로그램을 작성하시오.

www.acmicpc.net

 

#작성 코드

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
#include <iostream>
using namespace std;
 
int n;
int two, five=0;
 
int main(){
    cin>>n;
    
    // 2부터 시작해서 n까지의 수에 2와 5가 인수로 몇 개 존재하는지 센다 
    for(int i=2; i<=n; i++){
        int tmp=i;
        while( tmp%2==0 ){
            tmp = tmp/2;
            two++;
        }
        while( tmp%5==0 ){
            tmp = tmp/5;
            five++;
        }
    }
    
    // 2*5=10
    // 10은 2와 5의 개수 중 더 작은것만큼 만들 수 있다. 
    int result = min(two, five);
    cout<<result<<'\n';
    return 0;
}
cs

##

N!은 1부터 N까지의 곱이다.

-> N!에서 0이 아닌 수가 나올 때까지 등장하는 0의 개수는 N!에 약수로 10이 몇 개 존재하는지 묻는 것이다.

-> 10은 2 * 5이므로 N!에 2와 5가 몇 개 들어있는지 센다.

-> 2부터 N까지의 수를 반복하여 2와 5로 얼마나 나누어떨어지는지 체크하고, 나누어떨어지면 2또는 5 중 해당하는 수의 개수를 하나 늘린다.

2와 5가 a, b개 존재한다면 만들 수 있는 10은 최대 min(a, b)개이다.

'BOJ' 카테고리의 다른 글

BOJ 1920번 :: 수 찾기  (0) 2019.12.25
BOJ 2004번 :: 조합 0의 개수  (0) 2019.12.25
BOJ 1956번 :: 운동  (0) 2019.12.25
BOJ 1629번 :: 곱셈  (0) 2019.12.24
BOJ 1780번 :: 종이의 개수  (0) 2019.12.24

+ Recent posts