컴공 일기 246
게시글 주소: https://orbi.kr/00068783679
… 예… 오랜만에 들어와서 요새 풀고 있는 알고리즘 코드 하나 올려놓고 갑니다…
여전히 꽤…는 아니어도 열심히는 사는 중입니다…
간단한 해설을 하자면 소수를 찾는 알고리즘입니다.
주로 Sieve of Eratosthenes, 에라토스테네스의 체라고 얘기합니다. 컴퓨터에서 소수를 찾는 여러가지 방법이 있습니다만, 학부 수준에서 가장 이해하기 쉽고 직관적인 알고리즘이라고 할 수 있겠네요.
소수가 아닌 게 확실한 수를 지워나가는 방식입니다. 그래서 ‘체’라는 말을 쓰죠. 걸러낸다는 거예요.
그럼 뭘 걸러내면 될까요? “배수”들을 걸러내는 겁니다.
2의 배수, 3의 배수, 4의 배수, 5의 배수, 6의 배수…. 등등 전부요.
예를 잠깐 들어볼까요? 만약에 1부터 100까지의 자연수 범위에서 소수를 찾고 싶으면, sqrt(100) 즉 10의 배수까지 다 지워내면 됩니다. 어? 100까지니까 100의 배수까지 지워야 되는 게 아니냐고요?
사실 맞습니다만, 10의 배수까지만 탐색해도 전부 탐색할 수 있습니다. 만약 N이 소수가 아니라서 a * b의 형태를 이룬다면 즉, N = a * b 라면, a와 b의 최댓값은 루트 N입니다. a와 b는 모두 자연수이기 때문이지요. 만약 둘 중 한 수가 루트 N을 초과하는 순간, a * b의 값은 N을 넘어서게 됩니다. 따라서, 루트N까지 탐색의 범위를 제한해도 무방합니다.
에라토스테네스의 체는 이중반복문으로 구현이 되어서 얼핏 O(N^2)의 부담스런 시간복잡도를 가지는 듯 하지만,
실상은 그렇지 않습니다. 왜냐하면 대다수의 경우가 if(prime[i] == 0) continue;를 충족시키기 때문이지요…
말하자면 그 전에 지워낸 게 많아서, 새로운 배수에서 소수가 아닌 수를 지울 때, 탐색해야 할 후보군이 많이 없다는 뜻입니다.
그 효율성 때문에 알고리즘 문제에서 자주 이용된다.. 뭐 그리 생각하면 됩니다.
오늘도 재미있는 공학 시간..
#include <iostream>
#include <cmath>
#define MAX 1000001
using namespace std;
int prime[MAX];
int n, a, b, result;
int main()
{
cin.tie(NULL);
ios::sync_with_stdio(false);
for(int i=2; i<MAX; i++)
{
prime[i] = i;
}
for(int i=2; i<sqrt(N); i++)
{
If(prime[i] == 0) continue;
for(int j=i * i; j < MAX; j+=i)
{
prime[j] = 0;
}
}
while(1)
{
cin >> n;
if(n == 0) break;
for(int i=3; i < MAX; i++)
{
if(prime[i] != 0)
{
if(n - prime[i] != 0)
{
a = i;
b = n - prime[i];
break;
}
}
}
cout << n << " = " << a << " + " << b << "\n";
}
}
0 XDK (+0)
유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.
-
기만러가되고싶어 0
그런사람이되고싶어
-
이거 진짜인지 가짜인지 모르겠네 누르면 해킹당하겠져
-
추합이라 이미 입금기한은 지났던데..
-
잡생각 사라지게
-
내가 똥글싸지를 때마다 혈압오를거 아녀 ㅋㅋ
-
조금만 스치거나 지우개로 지워도 자국 남아서 짜증나는데 Hb쓸땐 안그랫음
-
과외 딱하나만 더구할까 11
전단지 돌리면 2,3개들어와서 아까운데 돈이 넘길친구도 마땅히 없고
-
상담하고 왔는데 0
너무 공부안했다고 자책하는 거 부터 버려야 할 거 같음. 그냥 하면 하는거고 안하면...
-
올해 94 97 2 99 99 설대식 394받고 고경 설대 경영가고싶어서...
-
대학생 생활비 1
그냥 술자리 적당히 가지고 무난무난하게 대학생활하면 얼마드나요?
-
이제 깔끔해졌으려나요
-
어찌하리
-
학교 행사중이었는데 딸래미 고등학교 여기 보내여한다고 입시상담요청하길래 좀 얘기하다...
-
ㅈㄱㄴ
-
ㅈㄱㄴ
-
25 오뿡이들 머임
-
그래서 고민 막상 붙으니 이거 고민되네 그냥 노줌 스나라
-
오르비언들 ㅃㄹ 지원 ㄱㄱ 제가 질문해야됨
-
아오 콘서타 2
다 떨어져서 안 먹고 있는데 레전드로 힘듦 내일까지 버티면 됨
-
도서관인데 들켰는데 옯이 뭔지 모르는 는치임 다행이노
-
진학사 점공 0
점공상 합격이면 웬만하면 합격이죠?? 점공상으론 2차에서 합격했어야하는데 안돼서...
-
화작확통생윤사문>>역대급 가성비 개꿀통 표본 역대급 담요단 조합으로 의대를 붙네... 와
-
그분들이 저를 받아주실지가 의문ㅠㅠ
-
스카나 가야지 0
ㅠㅠㅠ
-
저거면 만화책이 몇권이야...
-
중대 경영 붙었습니다 21
이제 삼수 ㄱㄱㅆ~~
-
이거 어카냐
-
서강대 합격생을 위한 노크선배 꿀팁 [서강대 25][뻔선뻔후] 0
대학커뮤니티 노크에서 선발한 서강대 선배가 오르비에 있는 예비 서강대생, 서대...
-
마스터 계정이 없어서 그런가
-
정병훈t랑 비슷한가요???
-
ㅅㅂ
-
(서울대 합격 / 합격자인증)(스누라이프) 서울대 25학번을 찾습니다. 0
안녕하세요. 서울대 커뮤니티 SNULife 오픈챗 준비팀입니다. 서울대 25학번...
-
집옴 2
피곤해죽겟다
-
심 5
심
-
누굴까 맞혀보셈
-
아이돌 앨범 커버 사진 올려도 되는거??
-
하 떨린다 1
중대 심리 4명 빠져야 붙는데 내 앞에 3명 슬슬 중대 경영 합격한 것 같은데...
-
언급이 없네 왜 와이
-
아 내일 8시에 깨야되는데 개조졌네
-
같이 살기
-
15분거리 12분만에 도달 땀 ㅈㄴ나네 근데 화장실을 못감 40분버티기 가능한가
-
배부르잖아 2
졸리잖아
-
좀 늦은거같지만 생2 하기로 했습니다 커리는 uaa풀커리로 믿고가보겠습니다. 옯클...
-
이제 막 지2 입문한 예비 물2지2러입니다.지2 고수분들이라면 다 아실수도 있을거라...
군대에서 코딩은 어떤 앱으로 하고 계신가요?