所谓的一数三平方:指一个6位数,本身是一个数字的平方,其前三位也是一个数的平方,后三位也是一个数字的平方,代码如下:
#include<stdio.h>
#include<math.h>
main()
{
long num,n,n1,n2,n3,n4,count=0;
for(num=100000;num<=999999;num++)
{
n=(long)sqrt(num);
if(num==n*n)
{
n1=num/1000;
n2=num%1000;
n3=(long)sqrt(n1);
n4=(long)sqrt(n2);
if(n1==n3*n3&&n2==n4*n4)
{
count++;
printf("%ld ",num);
}
}
}
printf("\n这样的数字一共有%ld个\n",count);
}
其中n=(long)sqrt(num);用到了sqrt()函数;
double sqrt(double num);
sqrt的返回值是一个double型,再将其转换成长整型,是的开方后的得到数字失去小数点后面的部分,那么强制转换后的再平方,所得的结果将不会等于原来开方前的数字,如果开平方后的数字小数部分为零,则将其转换成长整型也就不会产生数据的流失,再平方就会等于原来的数字,可利用这个方法就可以很好,判断出一个数字的开平方后得到的数字是否是整数;