LeetCode (7)Reverse Integer

31 篇文章 0 订阅

(7)Reverse Integer

题目:把数字倒过来。

例子:x = 123, return 321。

再例:x = -123, return -321。

另:输入是32位有符号整数,当超出范围的时候,输出0。

根据这个题目,想到的就是字符串,直接使用字符串处理就可以反过来输出。但是通过另外的最后一句话,我们不难发现,数字的范围仅在-2^31~2^31之间,那么需要处理的就只有0,数字超过10位或在等于十位的时候,与2^31比较大小就可以了。

下面是代码:

class Solution {
public:
    int reverse(int x) {
        string str = "";
        int i = 0;
        unsigned int x1 = x>0?x:(0-x);
        if(x == 0){
            return 0;
        }
        while(x1!=0){
            str += ( x1 % 10 ) + '0';
            i ++;
            x1 = x1/10;
        }
        if(str.size()>10){
            return 0;
        }
        if((str.size()==10)&&(str.compare("2147483647")>0)){
            return 0;
        }
        else{
            if(x<0){
                return 0-std::stoi(str);
            }
            else{
                return std::stoi(str);
            }
        }
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值