-
描述
-
最近Topcoder的XD遇到了一个难题,倘若一个数的三次方的后三位是111,他把这样的数称为小光棍数。他已经知道了第一个小光棍数是471,471的三次方是104487111,现在他想知道第m(m<=10000000000)个小光棍数是多少?
-
输入
- 有多组测试数据。第一行一个整数n,表示有n组测试数据。接下来的每行有一个整数m。 输出
- 输出第m个小光棍数。 样例输入
-
1 1
样例输出
-
471
分析:例如13*13=169 113*113=1469;即几位数相乘;后几位不变,结果的后几位也不变。
- /*同余定理 即 a≡ b(mod d) 也就是a%m==b%m则存在一个k使得a=b+k*m
- 这道题 a = 471 mod 1000 => a = 471 + 1000*m
- 由于471是第一个所以a = 471 + 1000*(m-1)
- */
- #include<stdio.h>
- int main()
- {
- long long m;
- int t;
- scanf("%d",&t);
- while(t--)
- {
- scanf("%lld",&m);
- printf("%lld\n",471+1000*(m-1));
- }
- return 0;
- }