
C语言编程题:所谓“同构数”是指这样一个数,它出现在它的平方数的右侧,例如5的平方是25,25的平方是
所谓“同构数”是指这样一个数,它出现在它的平方数的右侧,例如5的平方是25,25的平方是625,故5和25都是同构数,求[1,1000]之间所有同构数之和...
所谓“同构数”是指这样一个数,它出现在它的平方数的右侧,例如5的平方是25,25的平方是625,故5和25都是同构数,求[1,1000]之间所有同构数之和
展开
1个回答
展开全部
#include<stdio.h>
void main()
{
int m;
int s=0;
for(m=1;m<=1000;m++)
{
if((m*m)%10==m || (m*m)%100==m || (m*m)%1000==m)
{
s+=m;
}
}
printf("%d\n",s);
}
void main()
{
int m;
int s=0;
for(m=1;m<=1000;m++)
{
if((m*m)%10==m || (m*m)%100==m || (m*m)%1000==m)
{
s+=m;
}
}
printf("%d\n",s);
}
追问
结果好像是1113;你这是1114
追答
我这种算法把1也算作同构数,如果1不算作在他自己右边的话,那就改一下
if (((m*m)%10==m || (m*m)%100==m || (m*m)%1000==m) && m*m!=m)
把这句换了就行
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询