题目描述:
守形数是这样一种整数,它的平方的低位部分等于它本身。 比如25的平方是625,低位部分是25,因此25是一个守形数。 编一个程序,判断N是否为守形数
输入描述:
输入包括1个整数N,2<=N<100。
输出描述:
可能有多组测试数据,对于每组数据,
输出”Yes!”表示N是守形数。
输出”No!”表示N不是守形数。
代码
#include<stdio.h>
int len(int N)
{
int c=0;
while(N!=0)
{
c++;
N-=N%10;
N/=10;
}
return c;
}
void f(int N,int len)
{
int s=N*N;
int t=1;
while(len--) t*=10;
if(s%t==N)
printf("Yes!\n");
else
printf("No!\n");
}
int main()
{
int N;
while(scanf("%d",&N)!=EOF)
{
f(N,len(N));
}
return 0;
}