일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- AWS
- 장고
- API
- 알고리즘
- es6
- PYTHON
- Algorithm
- CSS
- Git
- 알고리즘 연습
- form
- MAC
- HTML
- 파이썬
- c++
- 파이썬 알고리즘
- react
- Baekjoon
- django widget
- javascript
- Django
- 백준
- django ORM
- django rest framework
- java
- 알고리즘 풀이
- web
- DRF
- js
- 알고리즘 문제
Archives
- Today
- Total
수학과의 좌충우돌 프로그래밍
[C++] 최적의 소수찾기, 에라토스테네스의 체 본문
안녕하세요 강민성입니다.
이번 포스팅에서는 소수를 찾는 방법에 대해서 알아보도록 하겠습니다.
소수를 찾는 방법이 여러가지가 있지만 그 중에 가장 효율이 좋은
'에라토스테네스의 체' 에 대해서 알아보도록 합시다.
최적의 소수 찾기, 에라토스테네스의 체
먼저 동영상을 보고 어떠한 원리로 소수를 찾는지 보도록 하겠습니다.
2부터 120까지 수 중 소수를 판별한다고 해보겠습니다.
다음과 같은 알고리즘으로 소수를 찾게 됩니다.
1. 2는 소수이므로 오른쪽에 2를 쓰고 2의 배수들은 소수가 아니므로 체크한다.
2. 다음 숫자를 확인하여 체크가 안되있으면 그 수를 오른쪽에 쓰고 그 수의 배수들은 체크,
체크가 되어있으면 다음 수로 넘어간다.
3. 120의 제곱근까지 다음 과정을 반복한다.
이 알고리즘을 이제 C++ 언어로 구현해보겠습니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | #include <iostream> #include <math.h> // 에라토스테네스의 체 #define SIZE 100 int arr[SIZE+1]; int main(int argc, const char *argv[]) { int i,j; // 배열 초기화 for(i=2;i<=SIZE;i++){ arr[i] = i; } for (i=2;i<=sqrt(SIZE);i++){ // 이미 체크된 수의 배수들은 합성수임이 자명 if(arr[i] == 0) continue; // i를 제외한 i의 배수들을 0으로 체크 for (j=i+i;j<=SIZE;j+=i){ arr[j] = 0; } } int count = 0; for(i=2;i<=SIZE;i++){ if (arr[i]!=0){ std::cout.width(3); std::cout << arr[i]; // 5개씩 출력하기 위한 count++; if (count % 5== 0) std::cout << std::endl; } } } | cs |
마무리
개인적으로 이름이 너무 어렵다고 생각합니다..
이 방식으로 소수를 구하지 않으면 시간복잡도에 걸리는 문제가 많아,
프로그래밍 언어로는 몇 번 구현을 해보았지만
아직도 이름이 헷갈려서 이번 포스팅 때도 이름을 다시 찾아보았습니다.
여러분은 특이한 이름이니만큼 잘 기억해두셨다가 요긴하게 쓰셨으면 좋겠습니다.
'알고리즘 > C++' 카테고리의 다른 글
[C++] BAEKJOON 5052번 전화번호목록 (0) | 2019.08.26 |
---|---|
[C++] BAEKJOON 8901번 화학제품(ACM-ICPC Daejeon 2011) (0) | 2019.08.02 |
[C++] BAEKJOON 8895번 막대배치(ACM-ICPC Daejeon 2012) (2) | 2019.07.31 |
[C++] BAEKJOON 9455번 박스(ACM-ICPC Daejeon 2013) (0) | 2019.07.26 |
[C++] 이진 탐색 알고리즘 (1) | 2019.03.26 |
Comments