【问题描述】
具有下面性质的数a称为"同构数":设b是a的平方,a与b的低若干位相同。
例如,5是25的同构数,25是625的同构数编程序满足如下要求:输入两个整数a,b(0<=a,b<=99),找出a、b之间全部的同构数。
【输入形式】
从键盘输入0-99之间的两个整数a和b,以空格隔开。
【输出形式】
在屏幕上按照由小到大的顺序输出所有同构数,每一个整数占一行。
【输入样例】
0 30
【输出样例】
0
5
6
25
代码示例:
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
/*同构数*/
void tg_num(int a,int b);
int main()
{int a,b;scanf("%d %d",&a,&b);tg_num(a,b);
}void tg_num(int a,int b)
{int ch,i,j_num,j,ch_num,flag;for(i=a;i<b+1;i++){// printf("%d ",i);j=i;ch=i*i;flag=1;while(j!=0){j_num=j%10;ch_num=ch%10;if(j_num!=ch_num){flag=0;break;}j=j/10;ch=ch/10;}if(flag==1)printf("%d ",i);}
}
输出:
注意事项:代码喜欢写错,尽量用显著的变量命名。
要考虑a为0的情况,因此加上了flag