Đề bài: Cho số nguyên N (1 <= N <= 2 * 10^6) nhập từ bàn phím. Hãy đưa ra số M là số nguyên tố gần với N nhất. Số nguyên tố gần với N được định nghĩa là một số nguyên tố mà khoảng cách từ N tới nó là nhỏ nhất. Nếu ta tìm được 2 số nguyên tố có cùng khoảng cách tới N, ưu tiên in ra màn hình số nhỏ hơn (codelearn.io - practice easy).
Testcase #1:
Input:
51
Output:
53
Testcase #2:
Input:
1000
Output:
997
Solution: Dựng sàng Eratosthenes, sau đó tìm số nguyên tố gần nhất bên trái và bên phải. Nếu khoảng cách đến số nguyên tố bên trái lớn hơn khoảng cách đến số bên phải thì in số bên phải ra, còn lại in số bên trái.
Code:
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
* https://github.com/trhgquan | |
*/ | |
#include <stdio.h> | |
int PRIME[2000004]; | |
void generatePrimes() { | |
for (int i = 2; i <= 2000004; ++i) | |
PRIME[i] = 1; | |
for (int i = 2; i <= 2000004; ++i) | |
for (int j = 2; j * i <= 2000004; ++j) | |
PRIME[i * j] = 0; | |
} | |
int nearestPrime(int n) { | |
// Special case: | |
if (n == 1) return 2; | |
generatePrimes(); | |
int a, b; | |
for (int i = n; i >= 2; --i) | |
if (PRIME[i]) { a = i; break; } | |
for (int i = n; i <= 2000004; ++i) | |
if (PRIME[i]) { b = i; break; } | |
if (n - a > b - n) return b; | |
return a; | |
} | |
int main() { | |
int n; | |
scanf("%d", &n); | |
printf("%d\n", nearestPrime(n)); | |
return 0; | |
} |
No comments:
Post a Comment