C语言对称数
问题描述:
输入一个整型数,判断是否是对称数,如果是,输出yes,否则输出no,不用考虑这个整型数过大,int类型存不下,不用考虑负值;
例如 12321是对称数,输出yes,124421是对称数,输出yes,1231不是对称数,输出no
实现思想:
非数组:通过取余运算“ % ”和取整运算“ / ”(算数运算),因为对称数的话将其进行翻转(通过刚刚说的取余、取整运算实现),比较两个数的大小是否一致,如果一致的话说明是对称数,如果不一致的话说明不是对称数。
数组:通过数组来保存输入整数的每一次数字,依次从前到后比较,完全一致则是对称数,否则不是。
代码:
// 非数组形式
#include<stdio.h>
int main() {
// 对称数的比较
int number;
int num = 0;
int flag; // 用于保存初始数值,用于最后的比较
printf("请输入数字:\n");
scanf("%d", &number);
flag = number;
while (number) {
num = num * 10 + (number % 10);
number /= 10;
printf("number = %d \n", number);
}
printf("num = %d \n", num);
if (num == flag) {
printf("yes");
}
else {
printf("no");
}
return 0;
}
// 数组形式
#include<stdio.h>
int main() {
// 对称数的比较
int number;
int num[10];
int flag = 0;
int i = 0;
scanf("%d", &number);
while (number) {
num[i++] = number % 10;
number /= 10;
}
for (int j = 0; j < i; j++) {
if (num[j] == num[i - j - 1]) {
printf("num[j] = %d, num[i - j -1] = %d \n", num[j], num[i - j - 1]);
continue;
}
else {
flag = 1;
break;
}
}
if (flag == 0) {
printf("yes");
}
else {
printf("no");
}
return 0;
}