小光棍数
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
1
-
描述
-
最近Topcoder的XD遇到了一个难题,倘若一个数的三次方的后三位是111,他把这样的数称为小光棍数。他已经知道了第一个小光棍数是471,471的三次方是104487111,现在他想知道第m(m<=10000000000)个小光棍数是多少?
-
输入
- 有多组测试数据。第一行一个整数n,表示有n组测试数据。接下来的每行有一个整数m。 输出
- 输出第m个小光棍数。 样例输入
-
1 1
样例输出
-
471
思路:
第一个是471.
后三位是111,只能n的末尾为471;
证明:
假设之后的数为m,有m=k+471;
m^3=(k^3+k(3*471^2)+k^2(3*471)+471^3);
其中471^3为XXX111.
则必有k^3+k(3*471^2)+k^2(3*471)=1000*p;
合并即为k*(k^2+3*471^2+k*3*471)=1000p
1.若k能被1000整除,满足题意
2.若k不能被1000整除,则k^2+3*471^2+k*3*471能被1000整除,假设k=t+x,其中t能被1000整除,x不能被1000整除,带入根据整除关系可化简为
x^2+3*471x+3*471^2能被1000整除,因为3*471^2=665523,可知x^2+3*471x的结果中末尾为477(k+477 k能被1000整除)才能满足题意。
假设结果为p+477,即可化简为:x^2+(157x-53)*9=k;
把x分个位数是0~9讨论,结果均得不出为0,即k不能被1000整除。矛盾而否定了假设2.
于是k能被1000整除。所以第一个数位471,以后的数为1000*i+471;
#include<stdio.h>
int main()
{
long long a,b,c,d,e;
scanf("%lld",&a);
while(a--)
{
scanf("%lld",&b);
printf("%lld\n",(b-1)*1000+471);
}
return 0;
}