第1个回答 推荐于2018-02-23
思路:同构数是会出现在它的平方的右边的数,先判断该数的为n,再判断该数平方的后n位是否等于该数。
参考代码:
#include <stdio.h>
#include<math.h>
int fun(int n){//求一个数的位数
int i=0;
while(n){
i++;
n/=10;
}
return i;
}
int main()
{
int a;
scanf("%d",&a);
if((a*a)%(int)pow(10,fun(a))==a)
printf("%d是同构数\n",a);
else
printf("%d不是同构数\n",a);
return 0;
}
/*
6
6是同构数
*/
本回答被网友采纳
第2个回答 推荐于2017-09-22
#include "stdio.h"
void main( )
{ long int m,m1,n,a,b;
scanf("%ld",&m);
m1=m;
n=m*m1;
while(m1)
{ a=m1%10; b=n%10;
if(a!=b) break;
m1=m1/10; n=n/10;
}
if(m1!=0) printf("%d不是一个同构数");
else printf("%d是一个同构数");
}本回答被提问者采纳
第3个回答 2013-03-27
#include<iostream>
using namespace std;
int main()
{
long shuru,fang,k=10;
cin>>shuru;
for (;;){if(shuru<k)break;k*=10;}
fang=shuru*shuru;
if(fang%k==shuru)cout<<"yes"<<endl;
else cout<<"no"<<endl;
return 0;
}
第4个回答 2019-04-06
输入数据2-99
#include<stdio.h>
int main()
{
int x,a,b;
printf("输入整型数据x:");
scanf("%d",&x);
a=x*x;
if(a%10==x||a%100==x)
printf("x是同构数\n");
else
printf("x不是同构数\n");
}