判断一个整型数是不是对称数

Description

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

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

Input

一个整型数

Output

输出是yes,或者no

思路:所谓的对称数就是从左往右看和从右往左看是一样的。那么,将给的数从右往左得到他的逆置数,1234的逆置数是4321,12321的逆置数还是12321.如果逆置数==原数,那么就是对称数。

#include<stdio.h>
int main(){
	int a;
	int b=0;
	
	scanf("%d",&a);
	int a1=a;
	while(a){
		int tem=a%10;
		b+=tem;
		b*=10;
		a/=10;
	}
	if(a1==b/10){
		printf("yes");
	}else{
		printf("no");
	}
	
	return 0;
}

C语言代码如上:

其中,

  • a是原数
  • b/10是得到的逆置数
  • tem是将原数分解出来的个位、十位、百位……
  • a1是用于托管a的值,因为之后a的值会变化

所以:如果a1==b/10,那么是逆置数,否则不是。

得到元素的逆置数的过程为:

  1. 通过%10获取原数的最低位
  2. 通过/10使原数的次低位
  3. 每次获得的最低位累加并乘以10
  4. 最终得到的结果是逆置数的十倍
  5. 逆置数的十倍/10后就是逆置数
  • 16
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

01红C

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值