4647: 【GESP2409五级】挑战怪物
内存限制:128 MB
时间限制:1.000 S
评测方式:文本比较
命题人:
提交:1
解决:1
题目描述
输入
输出
样例输入 复制
3
6
188
9999
样例输出 复制
2
4
-1
提示
#include <bits/stdc++.h>
using namespace std;
vector < int > prime;
bool is_prime[100010];
void Eratosthenes(int n) {
is_prime[0] = is_prime[1] = false;
for (int i = 2; i <= n; ++i) is_prime[i] = true;
for (int i = 2; i <= n; ++i) {
if (is_prime[i]) {
prime.push_back(i);
if ((long long) i * i > n) continue;
for (int j = i * i; j <= n; j += i)
is_prime[j] = false;
}
}
}
int main() {
Eratosthenes(100000);
int t;
cin >> t;
while (t--) {
int tmp = 1;
int x;
cin >> x;
int ans = 0;
while (1) {
if (is_prime[x]) {
ans++;
break;
}
x -= tmp;
ans++;
if (x <= 0) {
if (x < 0) ans = -1;
break;
}
tmp *= 2;
}
cout << ans << "\n";
}
}