Tuesday, 15 October 2019

NEARPRIME - Số nguyên tố gần nhất

Đề 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:
/*
* 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;
}
view raw NEARPRIME.c hosted with ❤ by GitHub


No comments:

Post a Comment

Popular posts