一个正整数,如果从左向右读(称之为正序数)和从右向左读(称之为倒序数)是一样的,这样的数就叫回文数。任取一个正整数,如果不是回文数,将该数与他的倒序数相加,若其和不是回文数,则重复上述步骤,一直到获得回文数为止。
输出占一行,变换的过程中得到的数值,两个数之间用空格隔开。
输入:27228
输出:27228 109500 115401 219912
代码
#include<stdio.h>
int inverse(int n) //返回一个数的逆序数
{
int s=0;
while(n!=0)
{
s=s*10+n%10;
n/=10;
}
return s;
}
int main()
{
int n,m;
scanf("%d",&n);
while(m=inverse(n),m!=n)
{
printf("%d ",n);
n=m+n;
}
printf("%d\n",n);
return 0;
}
代码
#include<stdio.h>
int inverse(int n) //返回一个数的逆序数
{
int s=0;
while(n!=0)
{
s=s*10+n%10;
n/=10;
}
return s;
}
int main()
{
int n,m;
scanf("%d",&n);
for(;;)
{
m=inverse(n);
printf("%d ",n);
if(m==n) break;
n=m+n;
}
return 0;
}