蓝桥杯 排它平方数

题目标题: 排它平方数


    小明正看着 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");
}

点赞