[백준] 11653번 : 소인수분해
업데이트:
문제
정수 N이 주어졌을 때, 소인수분해하는 프로그램을 작성하시오.
입력
첫째 줄에 정수 N (1 ≤ N ≤ 10,000,000)이 주어진다.
출력
N의 소인수분해 결과를 한 줄에 하나씩 오름차순으로 출력한다. N이 1인 경우 아무것도 출력하지 않는다.
예제 입력 1
72
예제 출력 1
2
2
2
3
3
풀이 1 : 가장 단순한 풀이
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <math.h>
int main() {
int n;
scanf("%d", &n);
for (int i = 2; i <= n; i++) {
while (n % i == 0) {
n /= i;
printf("%d\n", i);
}
}
return 0;
}
알고리즘 [ 접근방법 ]
while문을 이용한 기본적인 소인수 분해이다.
while (n % i == 0) { // n이 소수일때
n /= i;
printf("%d\n", i);
}
n이 소수인경우에 실행되게 함으로써 소수로 나누어 떨어질때마다 이를 출력해준다. 그러나 한가지 처리속도 면에서 아쉬운 점이 보인다.
for (int i = 2; i <= n; i++)
for문을 2부터 n까지 전부 돌리기 때문에 비효율 적이다. 이를 해결하기 위해 제곱근을 활용한 풀이로 다시 풀어보았다.
풀이2 : 제곱근을 활용한 풀이
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <math.h>
int main() {
int n;
scanf("%d", &n);
double temp = sqrt(n);
for (int i = 2; i <= temp; i++) {
while (n % i == 0) {
n /= i;
printf("%d\n", i);
}
}
if (n != 1) printf("%d\n", n);
return 0;
}
알고리즘 [ 접근방법 ]
double temp = sqrt(n);
for (int i = 2; i <= temp; i++){
temp라는 변수를 하나 설정해 n의 제곱근을 대입해주고 for문을 temp까지만 돌아가도록 설정했다. 제곱근까지만 돌려도 괜찮은 이유는 이전 포스팅인 [백준] 2581번 : 소수에 설명해놨으므로 이를 참고하길 바란다.
그리고! 한가지 예외처리를 꼭 해줘야만 하는 부분이 있다. 사실 이부분 때문에 이 문제를 포스팅한다고 봐도 된다.
if (n != 1) printf("%d\n", n);
n이 1이 아닐때 n을 출력하는 코드인데 이는 제곱근을 사용했기 때문에 넣어줘여만 하는 코드이다. for문이 i=2부터 temp까지 돌아가게 되는데, 만약 n이 6이라고 하면 i=2부터 √6(≒2.xx)까지 for문이 돌아가므로 i=2일때 한번만 for문이 돌아가 6의 소수인 3이 포함되지 않는다. 이런 경우의 예외처리를 위해 위의 코드를 반드시 넣어줘야 한다.
댓글남기기