不用把他转成字符串再转成数字之类的,用数学解决就好!找出一个数的最后位就是将其对求余啊,找一个数有几位以前也有过啊,那不就过了嘛!
#include<bits/stdc++.h>//万能头
int main()
{
int n;
scanf("%d",&n);
int n0=n;//用于找的位数
int l=1;
while(n0>0){
l*=10;
n0/=10;
}//找n的位数并计算取余的数
if((n*n)%l==n)printf("%d 1",n);
else printf("%d 0",n);
return 0;
}
数学简化代码????????