【问题描述】
具有下面性质的数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
更多推荐
同构数(c语言)
发布评论