回文数
题目: 输入一个数,判断它是不是回文数。一个数从左边读和从右边读的结果是一模一样的话就是回文数,例如12321是回文数,12531不是回文数。
解析: 假设输入数为x,将x倒置为y,判断y是否等于x。若y=x,则x为回文数;若y!=x,则x不是回文数
x倒置为y的实现过程: x/10 — 将x向右移动一位;x%10 — 取x个位。若x为两位数,y的十位即为x%10,y的个位即为x/10,实现x倒置。利用while循环实现不同位数x的倒置,即当x>0时(x位数仍有位数没被读取), y = y * 10 + x % 10;x = x / 10;
实现多次回文数判断: 利用while循环,使用户控制判断次数
使用scanf要在最上方加入#define _CRT_SECURE_NO_WARNINGS
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
int num, x, y = 0;
int k = 0;
while (1)
{
printf("是否进行回文数判断\n");
printf("1-进行 0-退出\n");
scanf("%d", &k);
if (k == 1)
{
printf("请输入一位数:");
scanf("%d", &num);
x = num;
while (x > 0)
{
y = y * 10 + x % 10;
x = x / 10;
}
if (num == y) {
printf("%d是一个回文数\n", num);
}
else {
printf("%d不是一个回文数\n", num);
}
}
else if (k == 0)
{
break;
}
else
{
printf("输入错误\n");
}
}
return 0;
}