小光棍数
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
1
-
描述
-
最近Topcoder的XD遇到了一个难题,倘若一个数的三次方的后三位是111,他把这样的数称为小光棍数。他已经知道了第一个小光棍数是471,471的三次方是104487111,现在他想知道第m(m<=10000000000)个小光棍数是多少?
-
输入
- 有多组测试数据。第一行一个整数n,表示有n组测试数据。接下来的每行有一个整数m。 输出
- 输出第m个小光棍数。 样例输入
-
1 1
样例输出
-
471
-
-
解析:
-
m数据很大,时间限制时1S,肯定需要转换思想去解题。
-
发现一个数的三次方最后三位为111的数结尾都含有471.
第一个小光棍数是0471;
第二个小光棍数是1471;
第三个小光棍数是2471;
。
。
。
那么第n个小光棍数是(n-1)471;
-
-
程序如下:
-
#include<cstdio> int main() { int t; scanf("%d",&t); while(t--) { long long m; scanf("%lld",&m); if(m==1) printf("471\n"); else printf("%lld471\n",m-1); } return 0; }