小光棍数

描述

最近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+km
要想使最后三位为111,则小光棍数最后三位必须为471,因为(1000
d+471)^3最后三位数只有471决定
这道题 a = 471 mod 1000 => a = 471 + 1000m
由于471是第一个所以a = 471 + 1000
(m-1)
第一个是471.
后三位是111,只能n的末尾为471;
证明:
假设之后的数为m,有m=k+471;
m^3 =(k^3 +k(3471^2) +k^2 (3471)+471^3);
其中471^3为XXX111.
则必有k^3 +k (3471^2)+ k^2(3471)=1000p;
合并即为k
(k^2 +3471^2+k3471)=1000p
1.若k能被1000整除,满足题意
2.若k不能被1000整除,则k2+3*4712+k
3471能被1000整除,假设k=t+x,其中t能被1000整除,x不能被1000整除,带入根据整除关系可化简为
x^2 +3
471x+3471^2 能被1000整除,因为3471^2 =665523,可知x^2+3*471x的结果中末尾为477(k+477 k能被1000整除)才能满足题意。
假设结果为p+477,即可化简为:x^2+(157x-53)9=k;
把x分个位数是0~9讨论,结果均得不出为0,即k不能被1000整除。矛盾而否定了假设2.
于是k能被1000整除。所以第一个数位471,以后的数为1000
i+471;

代码

#include <bits/stdc++.h>

using namespace std;

int main()
{
    int n;
    cin>>n;
    while(n--)
    {
        long long m;
        cin>>m;
        cout << 471+1000*(m-1) << endl;
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值