C语言怎么判断一个数是否是回文数?

2024年11月16日 16:39
有5个网友回答
网友(1):

所谓回文数,就是说一个数字从左边读和从右边读的结果是一模一样的,比如12321。

以下是判断一个数是否为回文数的代码:

大致思路就是将一个数反着排列一遍,如果和原先的数一样,那么就是回文数。这个排列过程用到了余数和整除。比如986,经过排列后为689,就不是回文数。

扩展资料:

判断一个字符串是否为回文:

网友(2):

#include 
int main(){
int i=0,j,k=1,n,a[20];
scanf("%d",&n);
while(n) {a[i]=n%10;n/=10;i++;}
for(j=0;jif(a[j]!=a[i-j-1]) {k=0;break;}
k?printf("是回文"):printf("不是回文");
return 0;
}

网友(3):

#include
#include
int main()
{
int j, i;
char a[20];
scanf("%s",a);
j=strlen(a);
for(i=0;i{
if(a[i]!=a[j-i-1])//判断前后是否相等,不相等则跳出循环,
break;
}
if(i>=j/2) printf("yes\n");//判断是否跳出来的,若不是则输出yes,若是则输出no
else printf("no\n");
return 0;
}

网友(4):

#include
int main()
{
int num, temp;
int sum=0;
printf("Please input a number:");
scanf("%d", &num);
temp=num;
while(num)
{
sum = sum*10 + num%10;
num /= 10;
}
if(temp == sum)
printf("yes\n");
else
printf("no\n");
return 0;
}

网友(5):

int array[]={"12321"};

int num_str=0;
int i=0;
for(i=0;array[i]!='\0';i++)/*个数.*/
{
num_str++;
}
i=0;
while((array[0+i]==array[num_str-i])&&(i<=num_str-i))
{
i++;
}
if(num_str%2==0)/*偶数个数.*/
{
if(i==num_str/2) /*Compare until the middle two.*/
{
return 1;
}
else
{
return 0;
}
}
else /*奇数个数.*/
if(i==num_str/2+1) /*Compare until the middle one.*/
{
return 1;
}
else
{
return 0;
}