7.整数反转

![题目](https://img-blog.csdnimg.cn/20200331142515138.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NDQ4ODY2Nw==,size_16,color_FFFFFF,t_70)

思路:
利用字符串存入数组再取出,太繁琐,利用%、/取出int每一位上的数字,再利用a=a*10+num/10;求和得出反转数字,注意正负数对a值无影响。关键点在于处理整数溢出,这也是我一开始总是报错的地方。
是不是首先想到了查看int类型的数值范围:假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−2^31, 2^31 − 1]。


void test(){		
    int a = 964632435;
	a = a * 10;	
	cout<<a<<endl;//1056389758}

可见这个方法不可行,发生溢出后,数据已经改变了,通常是通过丢位操作使得值在int范围内。INT_MAX=0x7FFFFFFF,INT_MIN=0x7FFFFFFF+1。涉及乘法的时候应该用INT_MAX/10。

class Solution {
public:
    int reverse(int x) {
     long int a=0;
        int y=x;
        
        while(y)
        {if((a>INT_MAX/10)||(a<INT_MIN/10)) return 0;
            a=10*a+y%10;
            y/=10;
      }
        return a;
 
    }
};

python做法有点晕,还是等C++熟练一些再来填坑。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值