컴공 일기 246
… 예… 오랜만에 들어와서 요새 풀고 있는 알고리즘 코드 하나 올려놓고 갑니다…
여전히 꽤…는 아니어도 열심히는 사는 중입니다…
간단한 해설을 하자면 소수를 찾는 알고리즘입니다.
주로 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를 선물하세요.
-
11덮 0
화미영물지 84 96 2 45 45 어느 정도일까요
-
약 먹으면 졸리고 휴지로 막아도 금방 젖고 신경쓰이고.. 진심 x같네요ㅠㅠ
-
배포합니다. 이번에는 따로 해설이 제공되지는 않고 빠른 정답만 제공됩니다. 자유롭게...
-
88이면 1등급이려나요?
-
학교에서 내일 사설 친다는데
-
새벽 내내 잠 설치다가 계속 잡생각 하던 와중에 내가 아직도 생각 중이라는 걸...
-
기균이나 농어촌으로 메디컬가면 과외할때 말해야 하나 ..?
-
11덮생명지구 0
보정1컷 얼마나 나올까요?
-
유튜브 올리시는건가 신기신기
-
언매 93 미적 96 물리 47 (1찍맞) 지2 47 한국사 37 설공 드가자
-
50 44 48 사만다는 시간이 좀 널널한 줄 알았는데 마지막 도표가 최종...
-
제발 내년에 0
회사 아니고 캠퍼스에 있게 해주세요 비나이다
-
마음같아선 미적분하고싶은데 하면 대학 못갈거같네요,, 글고 수1도 계속보니까 나름...
-
이감 파이널 난이도 어떤 편인가요 독서 션티 찍기 한수 유데유데 이명학 심찬우 김범준 메가패스
-
국어 커리 섞어타면 ex) 문학-김승리T, 독서-정석민T 이런식으로 하면 김승리...
-
그냥 찰칵찰칵 찍는 놈은 뭐냐
-
흐흐 공부할맛나네 고대
-
..사귀자는건가
-
왜 서바보단 할만한거같지 서바를 20개는 풀었는데도 아직도 서바에 안절여진건가
-
나도 열심히했는데..
-
Eng 1
Substantial 상당한 Implement 시행하다 Competent유능한...
-
체력도 그렇고 여러모로 다음주 전에 뒤질거같은데.. 일주일 더 공부하나 뭐 크게...
-
자살하고싶다진짜
-
난이도 어떰?
-
더재미없는과목들을 하고 수학문제 풀면 수학 존나재밌음
-
제가 항공우주공학이나,기공을데가려하는데 중경외시 기공,인하대 항공우주를 재수로 가기...
-
ㅇㅇ.
-
내년 수능 응시 예정인데 시발점 대수, 미적분1 수강해도 상관없겠죠? 1
현우진T 조교님들은 되려 대수랑 미적분을 들어라고 하시는데 들어도 크게 상관없겠죠?
-
늦바람이 들어서 어차피 복학할 거 걍 남은 10일정도만 빡쌔게 하고 잘되면 좋지!...
-
수완 영어 실모 난이도 어떻다고 생각하심??
-
엉엉 풀고 채점하려는데 답지가 없음....
-
난 4페이지를 왜 풀었는가 주작도 이렇게는 못친다
-
코헨이 싱어에게 비판 할말로 “인간과동물을 종차에 근거해 차등적으로 대우해야한다”...
-
2015 시발점 2022 시발점 뭘 들어야 할지 고민임 3
교육과정 따라가면 2015 듣는 게 맞는 것 같은데 2022가 내용도 더 풍부해지고...
-
45언더로 잘 안내려가는데 뭔 적생모만 보면 후두둑이냐
-
맞팔구함
-
물리 파동 1
물리 자꾸 파동파트 틀리거나 시간 오래쓰는데 아직도 개념이 다 안잡혔나봐요 ㅠㅠ...
-
동아리 질문 6
대학에 다니는 한 학생이 대학 내 신생 사진동아리를 만들엇는데 아직 회원이 만든...
-
Cctv에 안찍혀서 못잡는다네요,, 학교에서 잃어버린거 잘 안찾아주는것같은데 이거 못찾을까요,,
-
확 덤벨 던져버릴까
-
근데 안나오겠지...
-
탓하게됨 그러고 현실을 생각하고 실모 함 찢음
-
2024 년 11 월 4 일 | 제 1216 호 2024 수능 D-10 아직 꿈속에...
-
봇치가 있으면 잣치도 있어야 하는거 아닌가요???
-
던질까말까 6
던 던 던 던
-
세종대 가잣! 3
합격해서 맛집 투어 하자!!마지막 10일 파이팅"!
-
아머리아파 2
이놈의감기
-
찍맞 하나 포함해서 81점
-
말릴까? 말리다가 나 맞는거아니냐?
군대에서 코딩은 어떤 앱으로 하고 계신가요?