这道题初一看以为要大数乘法。其实不用。
long long最大可以表示20位的十进制数(知道是9开头的19位的即可,多大不重要)
补充:int是20亿,10位数
注:下面这种写法是错误的,由于100还是int,因此结果出来还是int,因此会出现溢出问题。
long long x = 100 * 100;
这样写才是正确的。
long long x = (long long) 100 * 100;
剩下的就不难了,用数组来映射哪些数字出现过,哪些没有即可。
ac代码:
#include <iostream>
using namespace std;
bool isDif(int x, int* a)
{
while(x)
{
if(a[x % 10] == 0) a[x % 10] = 1;
else return false;
x /= 10;
}
return true;
}
bool judge(long long x, int* a)
{
while(x)
{
if(a[x % 10] == 1) return false;
x /= 10;
}
return true;
}
int main()
{
for(long long i = 102345; i <= 987654; i++)
{
int a[10] = {0};
if(i != 203879 && isDif(i, a))
{
long long x = (long long)i * (long long)i;
if(judge(x, a))
{
cout << i;
break;
}
}
}
}