컴공 일기 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
많관부
-
답은 맞았는데 밑줄친 부분이 조건으로 주어진거고 동그라미친게 제가 도출해내는...
-
일단 하루에 7시간이상 박을거긴한데..
-
지하철에서 여성 심폐소생술 안한게 욕먹을 행동일까요? 0
모든 커뮤니티에 화제를 모으고 있는 사건입니다. 현재 여기저기서 엄청난 갑론을박이...
-
퀄리티가 낮고 오류는 없는 게 더 낫다. 물론 퀄리티도 좋을수록 좋지만.
-
왜 내 주위에는 0
개시발 ㅂㅅ밖에 없을까 돈 맡기면 먹튀할 인간 천지임
-
[속보] 바이든, 미 민주당 대선 후보직 사퇴 당신의 제보가 뉴스로...
-
영문법의 핵심 원칙과 규칙을 간결하게 정리해 드립니다. 예문과 함께 적용시켜 학습...
-
법조계의 모든것 1편 16
학생 커뮤니티에 법조계 정보가 지극히 제한적인것같아 글 쓰고 갑니다 1. 변호사는...
-
생각보다 공부가 잘 돼서 놀라는 중 전에 다녔던 독재가 너무 교실 좁고,, 다...
-
놀라운 사실 - 7연패중인데 꼴지가 되질 못하고 있다
-
파데 킥오프 (완료) 기생집 2,3점 (진행중) 아이디어 기생집 4점 아이디어...
-
제 이미지는 어떠한가요 21
적어주시면 님 이미지도 적어드림
-
이정도 바람이면 쉽게 날아갈듯
-
책 추천합니다 0
어제까지 일주일동안 책만 읽었었는데 가장 재밌고 흥미로웠습니다. '성인의 연애란...
-
지방교대 4
다들 2025 정시 지방교대 70퍼컷 어느정도 보시나요?
-
8점 이하면 확통 선택이 더 합리적일지도.. 공부해보니 어차피 88점 이하는 문제...
군대에서 코딩은 어떤 앱으로 하고 계신가요?