寻找完美平方数

Posted ziwangahu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了寻找完美平方数相关的知识,希望对你有一定的参考价值。

/*实现一个函数,判断任一给定整数N是否满足条件:它是完全平方数,又至少有两位数字相同,如144、676等*/

步骤一:怎样找到完全平方数

步骤二:判断是否有两个数相同(双层判断)

对于此题,我浪费的时间在怎样判断一个数是完全平方数,一开始用循环去判断,导致程序运行时间太长,放回不出结果。

解决思路:sqrt()函数原本返回的是double类型,现在我只取整数部分,如果r的平方还能与N相等,说明r本身就是整数,即N为完全平方数。

将N中的每一位提取出来,放在num数组数组中。最后双重循环判断是否有相同的数。

int IsTheNumber( const int N)
{
int r= sqrt(N);
int temp = N;
int num[20];
int tag=0;
int i=0;
int j;
int length;
if(r*r == N)
{
do
{

num[i]=temp % 10;
temp = temp /10;
i++ ;
}while(temp !=0);
length =i;
for(i =0 ; i <length-1 ;i++)
{
for(j=i+1; j<=length-1 ; j++)
{
if(num[i] == num[j])
{
tag=1;
break;
}
}
}

}

return tag;
}

 

以上是关于寻找完美平方数的主要内容,如果未能解决你的问题,请参考以下文章

513. 完美平方

513. 完美平方

使用片段着色器在特定位置绘制完美的水平线

有人可以向我解释为啥完美平方是 O(sqrt(n)) 的运行时间吗?

Python如何判断和寻找完美数

LeetCode 507 完美数[枚举] HERODING的LeetCode之路