소인수분해 알고리즘 [Factorization Algorithm]
소인수분해 알고리즘 [Factorization Algorithm]
소인수분해
소인수분해란 1보다 큰 자연수를 소수의 곱(소수인 인수)으로 나타낸 것.
- 어떤 수를 소인수분해하려면 2부터 sqrt(N)까지 더 이상 나눌 수 없을 때까지 나눠보면 됨.
- 즉, 2로 더 이상 나눌 수 없다면 3으로 나눠보고 .. sqrt(N)까지 반복하면 됨.
자연수 N (N > 1)이 있을 때, 크게 두 가지 경우로 나눌 수 있음.
- N이 합성수 일 때
- N이 sqrt(N)보다 작거나 같은 소인수들로 이루어진 경우
- sqrt(N)보다 큰 소인수가 있는 경우
- 이 경우 그 소인수의 지수는 반드시 1임.
ex) N=28 -> 2^2*7, sqrt(28) = 5.xx
-->
sqrt(28) < 7
` 이며 7의 지수는 1임.
- N이 소수일 때
- N이 소수이면 1과 N이 소인수가 되므로 sqrt(N)보다 큰 소인수가 있는 경우와 동일한 조건.
sqrt(N)은 함수로 사용해서 할 수 도 있지만 p*p <= N
으로 판단하는게 더 빠름.
구현
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <vector>
using namespace std;
vector<pair<int, int> > v;
int main(){
int N; cin >> N;
for(int p=2; p*p<=N; ++p){
int cnt=0;
while(N%p==0){
N/=p;
cnt++;
}
if(cnt!=0) v.push_back(make_pair(p, cnt));
}
if(N != 1) {
v.push_back(make_pair(N, 1));
}
cout << "N의 소인수분해" << '\n';
for(int i=0; i<v.size(); ++i){
cout << v[i].first << '^' << v[i].second << '\n';
}
}
백준 2312번 : 수 복원하기
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
32
33
#include <iostream>
#include <vector>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(NULL);
int n, t; cin >> t;
while(t--) {
vector<pair<int,int>> factors;
cin >> n;
for(int i=2; i*i <= n; i++) {
int cnt=0;
while(n%i==0) {
n/=i;
cnt++;
}
if(cnt != 0) {
factors.push_back(make_pair(i,cnt));
}
}
if(n != 1) {
factors.push_back(make_pair(n,1));
}
for(int v=0;v<factors.size(); v++) {
cout << factors[v].first << ' ' << factors[v].second << '\n';
}
}
return 0;
}
This post is licensed under CC BY 4.0 by the author.