题目:

请你来实现一个 atoi 函数,使其能将字符串转换成整数。

  首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。

  当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号;假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。

  该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响。

  注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。

  在任何情况下,若函数不能进行有效的转换时,请返回 0。

说明:

  假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231,  231 − 1]。如果数值超过这个范围,qing返回  INT_MAX (231 − 1) 或 INT_MIN (−231) 。

示例 1:

输入: "42"
输出: 42

示例 2:

输入: "   -42"
输出: -42
解释: 第一个非空白字符为 '-', 它是一个负号。我们尽可能将负号与后面所有连续出现的数字组合起来,最后得到 -42 。

示例 3:

输入: "4193 with words"
输出: 4193
解释: 转换截止于数字 '3' ,因为它的下一个字符不为数字。

示例 4:

输入: "words and 987"
输出: 0
解释: 第一个非空字符是 'w', 但它不是数字或正、负号。因此无法执行有效的转换。

示例 5:

输入: "-91283472332"
输出: -2147483648
解释: 数字 "-91283472332" 超过 32 位有符号整数范围。
 因此返回 INT_MIN (−231) 。
看到这个题,题很长,我们先来分析一下题目:  1.如果非空字符的第一个是正号或者负号,将其选取,并和后面的数字连接起来。  2.如果非空字符的第一个是数字,将它和后面的数字连接起来。  3.如果非空字符的第一个既不是正号或负号,也不是数字,返回0。  4.如果字符串为空,或者字符串内只包含空字符,返回0。  5.如果第一个非空字符是正号或负号,但接下来的第二个字符不是数字,返回0。对于"+-5"、"+ 6"这两种情况,都返回0。   6.如果数值超过可表示的范围 [−2^31,  2^31 − 1],则返回  INT_MAX (2^31 − 1) 或 INT_MIN (−2^31) 。实现时用Integer.valueOf()函数抛出的异常来判断整数越界。代码如下:
class Solution {public int myAtoi(String str) {int len = str.length();int i = 0;while(i < len && str.charAt(i) == ' '){i++;}if(i == len || !((str.charAt(i) == '+') || (str.charAt(i) =='-') || (str.charAt(i) >= '0' &&  str.charAt(i) <= '9'))){return 0;}StringBuffer res = new StringBuffer();if(str.charAt(i) == '-'){res.append('-');i++;}else if(str.charAt(i) == '+'){res.append('+');i++;}if(i == len || !(str.charAt(i) >= '0' &&str.charAt(i) <= '9')){return 0;}while(i < len && (str.charAt(i) >= '0' && str.charAt(i) <= '9')){res.append(str.charAt(i));i++;}int num = Integer.valueOf(res.toString());try{return num;}catch (Exception e){if(res.substring(0,1).equals('-')){return Integer.MIN_VALUE;}else{return Integer.MAX_VALUE;}}}
}

转载于:https://www.cnblogs.com/youdiaodaxue16/p/10746346.html

字符串转换整数 (atoi)相关推荐

  1. c++ 32位有符号的整数_【LeetCode】字符串分类字符串转换整数 (atoi)

    " 摘要:本文主要讲述LeetCode字符串分类字符串转换整数 (atoi)解法.主要内容如下: 题目 示例 解题 " 01 - 题目 请你来实现一个 atoi 函数,使其能将字符 ...

  2. LeetCode8. 字符串转换整数 (atoi)

    LeetCode8. 字符串转换整数 (atoi) 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. 当我们 ...

  3. [DFA|有限状态机] leetcode 8 字符串转换整数(atoi)

    [DFA|有限状态机] leetcode 8 字符串转换整数(atoi) 1.题目 题目链接 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先,该函数会根据需要丢弃无用的开头空格字符, ...

  4. 力扣——字符串转换整数 (atoi)

    字符串转换整数 (atoi) 请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数). 函数 myAtoi(st ...

  5. Leetcode 129求根节点到叶节点数字之和、104二叉树的最大深度、8字符串转换整数(atoi)、82删除排序链表中的重复元素II、204二分查找、94二叉树的中序遍历、144二叉树的前序遍历

    Top1:Leetcode 129求根节点到叶节点数字之和 官方题解:https://leetcode.cn/problems/sum-root-to-leaf-numbers/solution/qi ...

  6. C++字符串转换整数 (atoi)

    字符串转换整数 (atoi) 一个小更新. 今天仔细的研究了一下int型越界的情况, 顺便把力扣的一道题做了. 请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 ...

  7. 8. 字符串转换整数 (atoi)(leetcode力扣算法 - java / rust)

    8. 字符串转换整数 (atoi): 请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数). 函数 myAto ...

  8. 8. 字符串转换整数 (atoi)(正则表达式)

    字符串转换整数--C, Python实现 1. 问题描述与分析 2. C语言实现 3. Python实现 3.1 普通判断法 3.2 正则表达式法 1. 问题描述与分析 问题描述: 问题分析: 该算法 ...

  9. 20190822:(leetcode习题)字符串转换整数 (atoi)

    字符串转换整数 题目 大致思路 代码实现 题目 大致思路 这题主要是乱,思路大家都很容易想,就是把各种情况给码出来就行了,大家见我的代码注释会比较清晰. 几个用得到的方法:trim和substring ...

最新文章

  1. [POJ3261] Milk Patterns
  2. iOS使用Workspace来管理多项目
  3. Java扫描注解下的包_使用Spring mvc 利用java的反射技术,来扫描对应包下的注解请求url 统一保存在数据库中...
  4. 从软件到数件,AI生态如何建立自己的“Android”?天云数据CEO直播详解,可预约 | 量子位·视点...
  5. Java笔记-多线程中同步加锁相关
  6. Python学习笔记(三)数据类型--Number类型
  7. JS 中类型和类型转换
  8. redis 数据类型详解 以及 redis适用场景场合
  9. 剑指offer面试题53 - I. 在排序数组中查找数字 I(二分查找)
  10. rgbdslam_v2编译过程中引起的needed by错误
  11. Maven如何手动添加jar包到本地Maven仓库
  12. 齐齐哈尔市全国计算机等级考试,2021年9月黑龙江省齐齐哈尔市全国计算机等级考试报名时间...
  13. 记一个bug:ImportError: cannot import name ‘comb‘
  14. 孤独者的自我救赎[自我的认知]
  15. 第三方测试什么意思?国内知名第三方测试公司排名
  16. java 山寨qq源代码_求一个山寨qq的源代码,要java语言的~谢谢
  17. 关于.Net MAUI
  18. Qt:可视化UI设计
  19. Centos 进入recovery模式,单用户模式
  20. linux pandas教程_pandas教程

热门文章

  1. 数据绑定(Binding)
  2. Caused by: java.sql.BatchUpdateException
  3. 【转】堆栈和托管堆 c#
  4. Linux下getsockopt/setsockopt 函数说明
  5. 计算机页面的滚动栏怎么拉长,长滚动网页页面设计技巧
  6. python脚本编写_【PyQGIS】编写用于处理框架(QGIS3)的Python脚本
  7. kd树 python实现_Python KD树实现+简单的KNN实现
  8. 置顶带滚动效果_高端大气的滚动条图表,你学会了还怕老板们不喜欢,不升职吗?...
  9. java跨域权重_爱站权重查询 API 接口请求调用
  10. @ini_get php,php中get_cfg_var()和ini_get()的用法及区别_php技巧_脚本之家