Lintcode 54. 转换字符串到整数

题目描述:

实现atoi这个函数,将一个字符串转换为整数。如果没有合法的整数,返回0。如果整数超出了32位整数的范围,返回INT_MAX(2147483647)如果是正整数,或者INT_MIN(-2147483648)如果是负整数。

样例:

"10" =>10
"-1" => -1
"123123123123123" => 2147483647

"1.0" => 1

"       k" =>0

代码:

public class Solution {
	public int atoi(String str) {
        // write your code here
        int num = 0,flag = 1,j=0,cc=-1;//flag标记正负,cc标记有无字母,无-1,有1
		String ss = null;
		if(str.equals("")) return 0;//如果为空串,直接返回0
		str = str.trim();
	
		if(str.indexOf('.')==-1) ss=str;//判断字符串中有无小数点,按小数点进行切分
		else{
			String[] array = str.split("\\.");//小数点切分使用split("\\."),而不是split(".")
			ss = array[0];
		}
		int len = ss.length();
		if(ss.charAt(0)=='-') {flag = -1;j=1;}//若第一位为符号位,则从第二位开始计算
		if(ss.charAt(0)=='+') {flag = 1;j=1;}
		
		for(int i=j; i < len ; i++){
		    if(ss.charAt(i)-'0'<0||ss.charAt(i)-'0'>=10){cc=1;break;}//如果遇到费数字的字符,后面的就不统计了
		    num = num*10 + (ss.charAt(i)-'0');	
		}
		if(len>10&&flag ==1&&cc==-1) return 2147483647;//大于32位的纯数字字符串,返回INT_MAX
		if(len>10&&flag ==-1&&cc==-1) return -2147483648;//小于32位的纯数字字符串,返回INT_MIN
		if(cc==1&&num==0) return 0;//如果是非数字字符串,直接返回0
		else{ 
		    if(num*flag==-2147483648&&flag ==1) return 2147483647;//输入为“2147483648”时,返回2147483647
		    else return num*flag;}
    }
	public static void main(String[] arsg){
		Solution so = new Solution();
		System.out.println(so.atoi("        112469032d53"));
	}
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值