【问题描述】
具有下面性质的数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语言)