일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 |
31 |
Tags
- Spring ipfs
- kotiln functional interface
- go
- 안정해시
- java 1509
- spring mongoTemplate switch
- spring mongodb
- 자바 백준 팩토리얼 개수
- java 팩토리얼 개수
- nodejs rabbitmq
- java 백준 1509
- javav 1676
- mongodb lookup
- Java Call By Refernce
- kotiln const
- ipfs singletone
- 익명 객체 @transactional
- 백준 2252 줄세우기
- spring mongoTemplate
- 자바 1676
- ipfs bean
- rabbitmq 싱글톤
- kotiln const val
- spring mongodb switch
- 백준 1504 java
- 전략 패턴이란
- 백준 특정한 최단 경로
- java 파티
- java 1238
- 백준 연결요소 자바
Archives
- Today
- Total
공부 흔적남기기
[JAVA] 백준 팩토리얼 0의 개수 1676 본문
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
반응형
'코테 > 백준' 카테고리의 다른 글
[백준] [JAVA] 줄세우기 2252 위상정렬 메모리 초과 (0) | 2024.11.04 |
---|---|
[JAVA] 백준 연결요소 11724 (0) | 2024.10.28 |
시간 복잡도 생각 with 백준 10815 숫자카드 (0) | 2023.04.20 |
[JAVA] 백준 베르트랑 공준 4948 (0) | 2022.03.02 |
[JAVA] 백준 설탕배달 2839 (0) | 2022.03.02 |