letcode-7-reverse interger

python:

python 的int不会越界,自带大数运算。所以必须判断反转后的值是否为32位。

import math
def reverse(self, x):
        #如果溢出int,返回0      
        p=[]
        if (x>-(math.pow(2,31))) & (x<2**31-1):
            s=str(x)[::-1]
            if(s[-1]=='-'):
                s=s[-1]+s[0:-1]
            p=int(s)
            if (p>-(math.pow(2,31))) & (p<2**31-1):
                return p
            else:
                return 0           
        else:
            return 0

值得之一的是,必须判断,翻转后的值是否会越界(不在[-2**31,2**31-1])。

str也是一种str的list,可以切片,倒序,连接(+)

math.pow()

java:

public int reverse(int x) {
        int val=0;
        if((x>-Math.pow(2,31))&&(x<(Math.pow(2,31)-1))) {
        	String str=String.valueOf(Math.abs(x));
        	StringBuffer s=new StringBuffer(str);
        	int flag=x<0?-1:1;
        	s.reverse(); 
        	try {
        	val=Integer.parseInt(s.toString())*flag;  
        	}catch(Exception e) {
        		val=0;
        	}       	
        }
        return val;
    }

Math.abs(x)

int->string:  String.valueOf(val);

string->stringbuffer:        StringBuffer s=new StringBuffer(str);

stringbuffer反转:s.reverse();

条件判断:       int flag=x<0?-1:1;

stringbuffer->int:stringbuffer->string->int。(Integer.parseInf的参数是string)

              str=int_obj.toString();

              Integer.parseInf(str);
捕捉异常:
            try {
            val=Integer.parseInt(s.toString())*flag; /**/

}catch(Exception e){}

全部评论

相关推荐

LazyBreeze:项目尽量体现你对技术的理解和深度,不是说把中间件用一下就完事了,你项目里面提到集群和分布式,你真在服务器上部署过吗,感觉太假了,第二个项目说自己用了微服务的什么组件,只是用了没有自己的思考,很难让面试官注意到你的简历。针对某几个技术点自己多思考一下,考虑一下有没有别的替代方案,可以写一下,即使没有真的实现
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务