小光棍数
描述
最近Topcoder的XD遇到了一个难题,倘若一个数的三次方的后三位是111,他把这样的数称为小光棍数。他已经知道了第一个小光棍数是471,471的三次方是104487111,现在他想知道第m(m<=10000000000)个小光棍数是多少?
输入
有多组测试数据。第一行一个整数n,表示有n组测试数据。接下来的每行有一个整数m。
输出
输出第m个小光棍数。
输入样例 1
1
1
输出样例 1
471
来源
基础题-数学类问题
同余定理 即 a三b mod m 则存在一个k使得a=b+k*m
这道题 a = 471 mod 1000 => a = 471 + 1000*m
由于471是第一个所以a = 471 + 1000*(m-1)
#include <bits/stdc++.h>
using namespace std;
int main()
{
long long m;
long long n;
long long s;
cin>>n;
while(n--)
{
cin>>m;
s=471+1000*(m-1);
cout<<s<<endl;
}
return 0;
}