컴공 일기 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
은행 qr 결제탭 찾다가 놓쳐버림 좀 잘 보이게 해놓으라고 아
-
으히ㅣ
-
생각보다 렉 안걸리고 빨리 되네요
-
간만에 모의고사 보러가서 너무떨려요..
-
다들 힘내보자구요
-
다른 학교도 교수님 입장 전까지 강의실에서 잡담소리 큰가요? 강의실 전체가...
-
헤헤
-
러셀 6모 0
언제 열리나요??
-
공부진짜재미없네 7
뭔 다 암기야 ㅅㅂ
-
참과 모순의 관계 모순(p and not p)거짓 모순거짓 대우명제는 무모순참...
-
시간 참 빠르네
-
심지어 교무실 들어가서 신청해야됨 ㅠㅠ
-
12000원 현금이라는건가
-
그냥 모평 안봐야겠다
-
잇올에 전화하니까 빨리 마감되어서 주의하라고 하고 이투스 247은 오프 신청에...
-
내년수능을 노리는게 맞을까 이번에 개빡세보이는데
-
현재 하고있는 뉴분감 복습이 끝나면 4의 규칙 시즌1을 푼 후 커넥션이나...
-
6평 접수했다 2
비록 노베상태지만 응시해봐야징~~
-
정국 혼란에 힘 못쓰는 원화…환율 1,500원 가나 1
https://n.news.naver.com/article/215/0001203820...
-
일하자 0
으아앙
-
22예시12를 참고했습니다만 12번 수준은 아닙니다.
-
지각 3
-
고2 아직 미적분, 수2 안 나갔는데 정시파이터 가능한가요? 2
수1만 두번 돌렸어요 이제 수1 기출 문제집 주문했고, 쎈c 할 차례입니다. 수2는...
-
6모 러셀 접수 2
폰이나 패드로 해도 접수 가능한가요..? Pc만 가능하고 그렇진 않은지 궁금합니다
-
배때지 십돼지 됐네
-
6평 입금 완료 3
운 좋게 집 앞 학원에서 받아주셨네요
-
피트 헤그세스 미국 국방장관이 최근 국방부에 배포한 ‘임시 국가 방어 전략...
-
가깝자나
-
프섹)거지 ㅇㅈ 2
내 크탈 ㅠㅠㅠ
-
얼버기 8
폐렴구균 복습 시작
-
여보쇼. 그.. 거기에..
-
떳으니까말하지!!!!
-
영공시 1
영어공부시작
-
ㅗㅗㅗ
-
89->90 이라는 가정하에 수능 전체에서 몇문제정도 더 맞춰야 평백 1이 오르나요
-
근데 진학사에선 0
국영수사과한 내신은 못 보냐 국영수과 국영수사 국영수사과 는 다 있는데;;
-
9시 부터 받으먼 딱 9시에 도착해도 되려나요 ㅠㅠ
-
22수능 택시에서 보시고 만점받으셨다함 진짜 씹곹
-
국일만 때 봤는데 저런게 있었나
-
가능하다면 대통령이 돼서 내 망해버린 인생을 조금이라도 살려다오...
-
등교중 2
-
그냥 수2인가
-
6평 신청 못하나요?? 자퇴 늦게해서 8월검고인데…
-
공부시작 1
이얍
-
얼버기 1
부지런행
-
벌써부터 일이 꼬이네 염병
-
계획 1
영어단어 영단어장 day 12(480단어)모르는 어휘 복습 수특 3강~도표...
-
“떨어진 시력도 회복” 한국 연구진, 세계 최초로 망막 재생 기술 개발 2
KAIST 김진우 교수 연구팀 손상된 시력도 회복시킬 수 있는 망막 재생 기술을...
-
응시 신청 접수 기간: 2025. 3. 31.(월) 09:00 ~ 4. 10.(목)...
-
D-227 0
영어 모의고사 분석 영어단어 day1(80단어) 생윤 1단원 복습 2단원 진도 수학...
군대에서 코딩은 어떤 앱으로 하고 계신가요?