4-7ある種類の完全な平方数を統計する


本題は1つの関数を実現することを要求して、いずれかの与えられた整数Nが条件を満たすかどうかを判断します:それは完全な平方数で、また少なくとも2つの数字が同じで、例えば144、676などです.
関数インタフェースの定義:
int IsTheNumber ( const int N ); ここで、Nはユーザが入力するパラメータである.Nが条件を満たす場合、関数は1を返さなければなりません.そうしないと0を返します.
審判試験プログラムのサンプル:

#include <stdio.h>
#include <math.h>

int IsTheNumber ( const int N );

int main()
{
    int n1, n2, i, cnt;

    scanf("%d %d", &n1, &n2);
    cnt = 0;
    for ( i=n1; i<=n2; i++ ) {
        if ( IsTheNumber(i) )
            cnt++;
    }
    printf("cnt = %d
"
, cnt); return 0; } /* */

入力サンプル:105,500出力サンプル:cnt=6解答プログラム:
int IsTheNumber ( const int N )  
{  int p,q;
p=(int)sqrt(N);
q=p*p;
if(q==N)
{int i;
int num[10]={0};
while(q>0)
{ 
for(i=0;i<10;i++)
{  if(q%10==i)
{ num[i]+=1;
if(num[i]==2) 
{return 1;}
}
}
q=q/10;
}
return 0;
}
return 0;
}