컴공 일기 246
게시글 주소: https://m.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
ㅠㅠ 공부나 할게
-
걍 만백 100 나오게 내주면 아무 원성도 없을텐데
-
가기전까지 휴강인지 아닌지 모름
-
원래 국어 고정 1이긴합니다 작년 69수능 전부 백분위 99 올해도 6 백분위 99...
-
마지막 0
9모 언매 35 36틀렸는데 화작 풀어보니 12분쓰고 하나 틀렸습니다 ㅠ 언매 계속 하는게 맞을까요
-
헉… ㅋㅋㅋㅋㅋ 사탐 유지만 하자 이제 (물론 국수는 더 올려야 함)
-
뭐가 문제지 진짜
-
기출 풀다가 지문 겁나 길어서 ㅅㅂ 뭐지 싶었는데 열심히 읽다보니.. 그 악명 높은...
-
지2 생2 난이도 11
뭐가 더 낮아요
-
보닌 21수능 물1을 잊을수가 없다 1회독 15분만에 끝나고 틀리면 ㅈ된다는...
-
저정도면 인바디어떤편임?
-
고2정파입니다 수능공부를 일찍 시작해서 강기분 새기분 끝냈고 수학은 지금...
-
현역 문과고 스카이&한의대 동시 지망합니다. 내신은 대학 따라 1.0X 후반~...
-
표절? 2
-
사탐런하기전에 0
자기 국영수 성적보고 앞으로 두달동안 매일 개념강의 + 마더텅 진도 뺄수 있겠다...
-
멋잇다멋잇어
-
문학파트에서 지문이랑 문제 같은 면에 배치해준거 뒷페이지로 문제 안넘어가고 지문이랑...
-
2024년 시행 고1~2 9월 학평 국어 분석과 변형문제 배포 0
안녕하세요. 나무아카데미입니다. 2024년 시행 고1 고2 9월 학평 국어 문학...
-
이메일 아이디를 만들라고 하는데 단어 선택 고민이에요 이메일로 사용하기에 괜찮은 단어 투표 부탁해요
-
이런것만 모아놓은 문제집 있나요? (기출문제집이요!) 사문 9모 화작 생윤 화학 번...
-
9월 가채점 결과만 봐서는 표준점수는 여전히 높으나 예상 등급컷도 많이 올라갔습니다...
-
그놈의 도표퍼즐은 걍 개ㅈ밥 허수컷 문항이니까 작년 9평 수능, 올해 9평 개념문항...
-
설마 지금까지 탐구과목을 전혀 공부하지 않은거니???????
-
아니 뭐 쉬운걸 누가 모르는게 아닌데 상식적으로 지금해서 1 받을거란 생각을 할...
-
논술 노베 4
논술 공부 아예 안 해본 정시러인데 수시로 논술쓰는게 의미 있을까요..? 문과고 글...
-
9평 화작 5컷 정도되고 3목표로 수능때까지 하나만 한다면 뭐하는게 좋을까요??...
-
지금부터 시작해서 1년동안 사탐만 하는 담요단들을 이길 수가 있다고?
-
지2러분들 4
천구는 그냥 많이 그려보면서 그리는 속도 올리는 연습 해야하나요
-
기출보다 실모많이푸는게 더나은거같은데 나만그런가
-
궁금
-
설마 학습능력이 있다면 수능도 50점되고 3연벙내진 않겠지 ㅋㅋ 에이 ㅋㅋ 희망사항맞음
-
내년에 볼건데 . 지금 일병임 .공부 거의 안하긴함
-
그래야 원서영역이라도 유리해짐 어차피 지금 런치는걸 실행에 옮길수있는건 국수 탄탄한...
-
열심히 해오던 기존 사탐분들 그리고 일찍 사탐런 한 사람들은 잘 맞을거임 ㅇㅇ
-
( 여론조사, 의대 증원, 철회+규모조정 61.5% vs 33.5% P윤석열 정부안 ) 1
https://m.newspim.com/news/view/20240906000049
-
지방에 살더라도 주말에는 자녀를 서울 대치동 학원가로 보내는 학부모들이 많다. 방학...
-
성적들을 보니 1
나도 휴학하고 3반수할걸 성적 잘나오는 3수생들 보고 드는 생각임
-
특특 0
특특+실전300 역학+전자기 끝내는데 대략 얼마나 걸릴까요?? 6,9모 둘다...
-
"쌤도 다운 받으랬어요"... 족집게 학원 못간 학생들, 불법 자료방 서성인다 19
대학수학능력시험(수능) 출제 교사들은 '독점 계약'까지 맺어가며 학원에 수억 원을...
-
예상 커트라인이 비슷한 평가원 시험과 비교한 정답률 자료입니다! 낮을수록 어려운...
-
문학인강추천점여 1
메가패스만 있고.. 불륨크지않은인강 찾고 있어요
-
ㅅㅂ 좀만 쿨 돌면 사탐런 글을 얼마나 싸는 겁니까 목표가 설대나 고대인 사람도...
-
국어 #16 #23 #26 #31 #36 92인줄 알았으나 26에 5마킹한다는게...
-
자사고 내신 인설의 노려볼만한 점수라 수능최저 과탐할수밖에 없는데 이번 물리 등급컷...
-
헉ㅋㅋㅋㅋ
-
누군가의 소비(손실)는 누군가의 소득(이득)이다 라는 냉혹한 경제원리를 미리미리...
-
그 전과목 파이널 시리즈+모의고사 70일동안 풀거 사니까 거즘 160가까이드는데...
-
다른 대학들도 수업하기전에 막 강의 미리 봐야하고 그러나요? 0
그냥 대면수업만 하는게 좋은데
-
친구 6모 화생 28 29받고 화학 지구로 돌려서 하루에 2시간씩 탐구해서 9모때...
군대에서 코딩은 어떤 앱으로 하고 계신가요?