8. String to Integer (atoi)


一,题目

Implement atoi to convert a string to an integer.

Hint: Carefully consider all possible input cases. If you want a challenge, please do not see below and ask yourself what are the possible input cases.

Notes: It is intended for this problem to be specified vaguely (ie, no given input specs). You are responsible to gather all the input requirements up front. 

二,思路

和数字翻转的类似


需要注意的点儿如下:
1,字符0-9的ascii码取值范围
2,前后空格的去除
3,首位正负号的去除
4,字符串中间的出现非0-9字符,则取消转换,得到的值是当前的
5,int类型溢出返回其int最大值或者最小值
6,使用long进行存放结果,但是存放结果的long值也可能出现溢出,所以每次遍历到一个合法字符都需要进行判断int类型是否溢出

三,代码

public int myAtoi(String str) {
		if(str == null || str.length() == 0){
			return 0;
		}
		str = str.trim();
		int pointer = 0;
		boolean isNegative = false;
		if(str.startsWith("-")){
			isNegative = true;
			pointer = 1;
		}
		
		if(str.startsWith("+")){
			pointer = 1;
		}
		long result =0;
		for(int i=pointer,len = str.length() ;i<len; i++){
			char c = str.charAt(i);
			//0的ascii码对应48,9的ascii码对应57
			if(c>=48 && c <= 57){
				result = result * 10 + (c -48);
			}else{
				break;
			}
			
			if(result >= Integer.MAX_VALUE && !isNegative){
				return Integer.MAX_VALUE;
			}
			
			if(result > Integer.MAX_VALUE ){
				result *= -1;
				if(result <= Integer.MIN_VALUE){
					return Integer.MIN_VALUE;
				}
				return Integer.MAX_VALUE;
			}
			
			
		}
		if(isNegative){
			result *= -1;
		}
		return (int)result;
	}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值