题目标题: 排它平方数
小明正看着 203879 这个数字发呆。
原来,203879 * 203879 = 41566646641
这有什么神奇呢?仔细观察,203879 是个6位数,并且它的每个数位上的数字都是不同的,并且它平方后的所有数位上都不出现组成它自身的数字。
具有这样特点的6位数还有一个,请你找出它!
再归纳一下筛选要求:
1. 6位正整数
2. 每个数位上的数字不同
3. 其平方数的每个数位不含原数字的任何组成数位
答案是一个6位的正整数。
请通过浏览器提交答案。
注意:只提交另一6位数,题中已经给出的这个不要提交。
注意:不要书写其它的内容(比如:说明性的文字)。
#include<stdio.h>
#include<stdlib.h>
void main()
{
int flag=0,flag2=0;
long long int a[12]={0};
long long int b[6]={0};
for(int i=123456;i<=987654;i++)
{
flag=0;
flag2=0;
b[0]=i/100000;
b[1]=(i%100000)/10000;
b[2]=(i%10000)/1000;
b[3]=(i%1000)/100;
b[4]=(i%100)/10;
b[5]=(i%10)/1;
for(int k=0;k<6;k++)
{
for(int j=0;j<6;j++)
{
if(j!=k&&b[k]==b[j])
{
flag=1;
break;
}
}
if(flag==1)
break;
}
if(flag==1)
continue;
int temp=0;
int num=0;
for(int h=5;h>=0;h--)
{
temp=b[h]*i+temp;
a[num]=temp%10;
num++;
temp/=10;
}
while(temp!=0)
{
a[num]=temp%10;
num++;
temp/=10;
}
for(int l=11;l>=0;l--)
{
if(a[l]!=0)
{
for(int g=l;g>=0;g--)
{
for(int y=0;y<6;y++)
{
if(a[g]==b[y])
flag2=1;
}
}
}
}
if(flag2==0)
{
printf("%d ",i);
for(int r=11;r>=0;r--)
printf("%d",a[r]);
printf("\n");
}
}
system("pause");
}