数字反转(如何判断回文数)

数字回文

在LeetCode的刷题的时候,碰见了一个很简单的题目:

判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。

看到题目的第一反应是将int转化成String然后再判断是否是回文。

仔细思考一下之后,发现数字的反转也是有规律可循的,根本不需要转化成字符串。代码如下:

        int x = 1213121;
        int rev = 0;
        int tmp = 0;
        while(rev < x){
            tmp = x%10; //取出当前的个位
            rev = rev*10 + tmp; 
            x = x/10;
        }

以反转x为例,思路就是不断的将x与10的余数取出来,每次取出之后将x除以10一遍取出下一位,这样数字就被反转过来了。

而上述实现代码中,rev只反转了一半,如果rev比x大(rev每次乘10,x每次除10),说明数字已经反转了一半。按照回文的思路,如果当前的x位数是单数,则rev会比x多出一位。回文的条件是x == rev/10。如果当前的x位数是双数,则rev和x相同位数,回文的条件是 x == rev。

所以最后判断是否是回文数的条件是 x == rev || x == rev/10 。

本文主要记录一个反转数字的思路,以后遇见数字相关的反转问题,千万不要再转成字符串处理!!!

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值