为了账号安全,请及时绑定邮箱和手机立即绑定

给定一个 32 位有符号整数,将整数中的数字进行反转。

标签:
Java
输入: 123输出: 321
输入: -123输出: -321
输入: 120输出: 21

注意:

假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−231,  231 − 1]。根据这个假设,如果反转后的整数溢出,则返回 0。

public int reverse(int x) {
    if (x <= Integer.MIN_VALUE || x >= Integer.MAX_VALUE) {
        return 0;
    }
    int z = 0;
    int n=0;
    while(x!=0){
        n++;
        if (n==10){
            if (x<0){
                if (z<Integer.MIN_VALUE/10){
                    return 0;
                }
            }
            else{
                if (z>Integer.MAX_VALUE/10){
                    return 0;
                }
            }
        }
        z = z * 10 + x % 10;
        x/=10;
    }
    return z;
}


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
JAVA开发工程师
手记
粉丝
56
获赞与收藏
363

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消