Codeforces Round #471 (Div. 2) C. Sad powers

首先可以前缀和 ans = solve(R) - solve(L-1)
对于solve(x) 1-x当中符合条件的数
分两种情况

  1. 3,5,7,9次方的数,注意这地方不能含有平方次
  2. 平方数
#include 
#include 
#include 
#include 
#include 

std::vector oddNumber;
bool isSqaure(long long x) {
    long long t1 = sqrt(x);
    return t1 * t1 == x;
}
void pre() {
    // get the a^p (p = 3,5,7,9)
    oddNumber.clear();
    for (long long i = 2; i < 1000001; ++i) {
        if (!isSqaure(i)) {
            long long initNumber = i * i * i;
            long long multiplyNumber = i * i;
            oddNumber.push_back(initNumber);
            while (1.0 * initNumber * multiplyNumber <= 1e18) {
                initNumber *= multiplyNumber;
                oddNumber.push_back(initNumber);
            }
        }
    }
    sort(oddNumber.begin(), oddNumber.end());
    oddNumber.erase(unique(oddNumber.begin(), oddNumber.end()), oddNumber.end());
}
long long solve(long long number) {
    if (number == 0)
        return 0;
    long long result = upper_bound(oddNumber.begin(), oddNumber.end(), number) - oddNumber.begin();

    result += (long long)sqrt(number);
    return result;
}
int main() {
    int Q;
    pre();
    while (~scanf("%d", &Q)) {
        for (int i = 0; i < Q; ++i) {
            long long L, R;
            scanf("%lld %lld", &L, &R);
            printf("%lld\n", solve(R) - solve(L - 1));
        }
    }
    return 0;
}

你可能感兴趣的:(Codeforces Round #471 (Div. 2) C. Sad powers)