C语言对称数

C语言对称数

问题描述:

输入一个整型数,判断是否是对称数,如果是,输出yes,否则输出no,不用考虑这个整型数过大,int类型存不下,不用考虑负值;

例如 12321是对称数,输出yes,124421是对称数,输出yes,1231不是对称数,输出no

实现思想:

非数组:通过取余运算“ % ”和取整运算“ / ”(算数运算),因为对称数的话将其进行翻转(通过刚刚说的取余、取整运算实现),比较两个数的大小是否一致,如果一致的话说明是对称数,如果不一致的话说明不是对称数。

数组:通过数组来保存输入整数的每一次数字,依次从前到后比较,完全一致则是对称数,否则不是。

代码:

// 非数组形式
#include
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
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;
} 

你可能感兴趣的:(c语言学习,c语言)