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