Участник:AlinaS/CUBEFREE

Материал из DISCOPAL
Перейти к: навигация, поиск

Задача https://www.spoj.com/submit/CUBEFR/

Компилятор C++ (gcc 8.3)

#include <bits/stdc++.h>
using namespace std;
 
const int MAXN = 1000001;
 
int T, N;
int cubes[MAXN], ids[MAXN];
 
int main(int argc, const char*argv[]) {
    for (int i=2; i*i*i<MAXN; i++) {
        int step = i*i*i;
        for (int j=step; j<MAXN; j += step) {
            cubes[j] = 1;
        }
    }
    for (int i=1; i<MAXN; i++) {
        ids[i] = ids[i-1] + 1 - cubes[i];
    }
    cin>>T;
    for (int k=0; k<T; k++) {
        cin>>N;
        cout<<"Case "<<k+1<<": ";
        if (cubes[N]) {
            cout<<"Not Cube Free"<<endl;
        }
        else {
            cout<<ids[N]<<endl;
        }
    }
}