#include<stdio.h>
using namespace std;
#define MAX 1000001
int t[MAX];
int main(){
	for(int i=0;i<MAX;i++)t[i]=0;
	for(int i=1;i*i*i<MAX;i++){
		for(int j=i+1;j*j<MAX;j++){
			for(int k=j+1;k<MAX;k++){
				if(i*j*k>=MAX)break;
				t[i*j*k]++;
			}
		}
	}
	for(int i=1;i<MAX;i++)t[i]+=t[i-1];
	int n;
	scanf("%d",&n);
	for(int i=0;i<n;i++){
		int a;
		scanf("%d",&a);
		printf("%d\n",t[a]);
	}
	return 0;
}
