经典算法-字符串转化为整数
2016-08-02 09:00
183 查看
经典算法题-把字符串转化为整数值
思路分析
首先判断字符串是否为空,返回0考虑前面的是否是空格,使用trim()去掉,然后判断长度是否为0,是的话,返回0
判断第一个字符是不是+和-,设置变量sign记录
循环取得字符串的数字,考虑字符串中有非数字,遇到就退出,保留前面的数字
考虑溢出的情况,溢出返回Integer的最大值或最小值
代码如下:
public class Solution { public static int myAutoNumber(String str){ //首先判断空值 if(str == null){ return 0; } //去掉空格的情况 str = str.trim(); if(str.length() == 0) return 0; //正负数标志 int sign = 1; int index = 0; if(str.charAt(index) == '+') index ++; else if(str.charAt(index) == '-'){ index ++; sign = -1; } //取得数字部分,遇到溢出和非数字退出 long number = 0; for(; index < str.length();index++){ if(str.charAt(index) < '0' && str.charAt(index) > '9'){ break; } number = number * 10 + (str.charAt(index) - '0'); if(number >= Integer.MAX_VALUE) break; } if(number * sign <= Integer.MIN_VALUE) return Integer.MIN_VALUE; if(number * sign >= Integer.MAX_VALUE) return Integer.MAX_VALUE; return (int) number * sign; } }
相关文章推荐
- 字符串转化为整数的算法改进及优化
- 【LeetCode-面试算法经典-Java实现】【008-String to Integer (atoi) (字符串转成整数)】
- 字符串转化为整数的算法改进及优化
- 算法(二)字符串转化为整数
- 【LeetCode-面试算法经典-Java实现】【008-String to Integer (atoi) (字符串转成整数)】
- 算法(四)字符串转化为整数相加
- 字符串转化为整数的算法改进及优化
- 【算法题】整数与字符串之间的相互转化
- 字符串分割+日期和整数的转化
- 正整数转成字符串 简单算法
- 整数 转化成 十六进制 字符串
- 经典笔试题:从十亿个整数中选择前100大整数的算法实现
- 相邻两方格内的两个整数之和为质数-经典算法详解
- 将整数转化为二进制字符串
- 经典算法题--求对策字符串的最大长度
- 将字符串转化为整数,如 "-123" --> -123
- C/C++面试之算法系列--atoi(char *str)将字符串转换成整数
- 经典算法(3)- 用二进制方法求两个整数的最大公约数(GCD)
- 不使用标准库函数实现整数与字符串转化
- 字符串分割+日期和整数的转化