试除法求约数个数。
int n;
int divisor(int n)
{
int res=0;
for(int i=1;i*i<=n;i++)
if(n % i == 0)
{
res++;
if(i != n/i) res++;
}
return res;
}
int main()
{
while(cin>>n && n)
{
for(int i=0;i<n;i++)
{
int x;
scanf("%d",&x);
cout<<divisor(x)<<endl;
}
}
//system("pause");
return 0;
}