小光棍数
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
1
-
描述
-
最近Topcoder的XD遇到了一个难题,倘若一个数的三次方的后三位是111,他把这样的数称为小光棍数。他已经知道了第一个小光棍数是471,471的三次方是104487111,现在他想知道第m(m<=10000000000)个小光棍数是多少?
-
输入
- 有多组测试数据。第一行一个整数n,表示有n组测试数据。接下来的每行有一个整数m。 输出
- 输出第m个小光棍数。 样例输入
-
1 1
样例输出
-
471
第一眼看到这题就应该懂它的套路,肯定尾数必须位471。
然后这题考察实际上是“同余函数”
思路:
第一个光棍数是471=>以后的每个光棍数x的后三位都是471=> x%1000=471
则由同余定理得 471≡x mod 1000=> x=1000k+471.
如果两个正整数 a和 b之差能被 n整除,那么我们就说 a和 b对模n同余,记作:
a ≡b (mod n)
#include <cstdio>
#include <iostream>
using namespace std;
int main()
{
int n;
scanf("%d",&n);
while(n--){
long long m;
scanf("%lld",&m);
printf("%lld",(m-1)*1000+471);
}
return 0;
}