描述
最近Topcoder的XD遇到了一个难题,倘若一个数的三次方的后三位是111,他把这样的数称为小光棍数。他已经知道了第一个小光棍数是471,471的三次方是104487111,现在他想知道第m(m<=10000000000)个小光棍数是多少?
-
输入
- 有多组测试数据。第一行一个整数n,表示有n组测试数据。接下来的每行有一个整数m。 输出
- 输出第m个小光棍数。 样例输入
-
1 1
样例输出
-
471
思路:从1到471才出现了一个小光棍数,可以试试三位数里还有没有小光棍数 试试证明没有了 所以 只有尾数为471才能在三次方后尾数为111;
#include <stdio.h>
int main()
{
int n;
scanf("%d", &n);
while (n--)
{
long long int a;
scanf("%lld", &a);
if (a == 1) printf("471\n");
else
{
printf("%lld%d\n", a-1, 471);
}
}
return 0;
}