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

首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。接下来的转化规则如下:

如果第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字字符组合起来,形成一个有符号整数。
假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成一个整数。
该字符串在有效的整数部分之后也可能会存在多余的字符,那么这些字符可以被忽略,它们对函数不应该造成影响。
注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换,即无法进行有效转换。

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

提示:

本题中的空白字符只包括空格字符 ’ ’ 。
假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231, 231 − 1]。如果数值超过这个范围,请返回 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 (−2^31) 。

C++
初稿

class Solution {public:int myAtoi(string s) {int i=0;bool fu = false;bool chara = false;vector <int> result;if(!s[0])return 0;while(s[i]==' '){i++;}if(s[i]=='-'&&fu==false&&chara==false){fu=true;chara = true;i++;}if(s[i]=='+'&&chara==false){chara = true;i++;}while(s[i]=='0'){i++;chara=true;}while(i<s.size()){if(s[i]>='0'&&s[i]<='9'){chara = true;result.push_back(s[i]-'0');}elsebreak;i++;}long sum=0;int len = result.size();i=0;if(len>10&&fu==false)return INT_MAX;if(len>10&&fu==true)return INT_MIN;while(i<result.size()){sum += pow(10,len-1)*(result[i]);i++;len--;}if(fu)sum = -sum;if(sum<INT_MIN)return INT_MIN;if(sum>INT_MAX)return INT_MAX;return sum;}
};

优化后

class Solution {public:int myAtoi(string s) {int i=0;bool fu = false;while(s[i]==' '){i++;}if(s[i]=='-'){fu=true;}if(s[i]=='+'||s[i]=='-'){i++;}int sum=0;while(i<s.size()&&isdigit(s[i])){int r = s[i]-'0';if(sum>INT_MAX/10||(INT_MAX/10==sum&&r>7))//也可用double,不过会慢。return fu? INT_MIN:INT_MAX;sum = sum*10 + r;i++;}return fu? -sum:sum;}
};

答案用的自动机DFA

class Automaton {string state = "start";unordered_map<string, vector<string>> table = {{"start", {"start", "signed", "in_number", "end"}},{"signed", {"end", "end", "in_number", "end"}},{"in_number", {"end", "end", "in_number", "end"}},{"end", {"end", "end", "end", "end"}}};int get_col(char c) {if (isspace(c)) return 0;if (c == '+' or c == '-') return 1;if (isdigit(c)) return 2;return 3;}
public:int sign = 1;long long ans = 0;void get(char c) {state = table[state][get_col(c)];if (state == "in_number") {ans = ans * 10 + c - '0';ans = sign == 1 ? min(ans, (long long)INT_MAX) : min(ans, -(long long)INT_MIN);}else if (state == "signed")sign = c == '+' ? 1 : -1;}
};class Solution {public:int myAtoi(string str) {Automaton automaton;for (char c : str)automaton.get(c);return automaton.sign * automaton.ans;}
};

附一个一行的python代码

class Solution:def myAtoi(self, s: str) -> int:return max(min(int(*re.findall('^[\+\-]?\d+', s.lstrip())), 2**31 - 1), -2**31)

由这个python代码想到了正则表达式
C++的正则表达式方法

class Solution {public:int sign = 1;int myAtoi(string s) {s.erase(0,s.find_first_not_of(" "));regex e("^[\\+\\-]?\\d+");smatch m;bool found = regex_search(s, m, e); int ans = 0;string resu = m.str(0);if(resu[0]=='-'){sign = -1;}if(resu[0]=='+'||resu[0]=='-'){resu.erase(0,1);}for(char c : resu){int num = c - '0';if(ans>INT_MAX/10||(ans==INT_MAX/10&&num>7)){return sign==1? INT_MAX:INT_MIN;} ans = ans * 10 + num;}return sign * ans;}
};

字符串转换成整数(3种方法)相关推荐

  1. java浮点数化为整数_[Java教程]javascript浮点数转换成整数三种方法

    [Java教程]javascript浮点数转换成整数三种方法 0 2014-06-24 04:00:27 将浮点数转换成整数方法有很多,分享三种常用方法. Summary 暂时我就想到3个方法而已.如 ...

  2. angular 字符串转换成数字_3种方法搞定Excel中数字大小写转换? 123...变为壹贰叁......

    作者 | 雷哥 编辑 | 小西瓜 职场中,大家是否遇到这样的情况, 需要把数字"1,2,3......" 转换为 大写的"壹贰叁...",大家都有哪些方法可以实 ...

  3. oracle 转化为整数,字符串转换成整数——从源码学习

    字符串转换成整数:输入一个表示整数的字符串,把该字符串转换成整数并输出,例如输入字符串"345",则输出整数345. 在笔试面试中,atoi 即「字符串转换成整数」是一个经典问题了 ...

  4. 程序员面试题精选100题(17)-把字符串转换成整数[算法]

    题目:输入一个表示整数的字符串,把该字符串转换成整数并输出.例如输入字符串"345",则输出整数345. 分析:这道题尽管不是很难,学过C/C++语言一般都能实现基本功能,但不同程 ...

  5. 剑指Offer(Java版):把字符串转换成整数

    2019独角兽企业重金招聘Python工程师标准>>> 题目:实现一个函数 stringToInt,实现把字符串转换成整数这个功能,不能使用 atoi 或者其他类似的库函数. 题目解 ...

  6. 程序员编程艺术第三十 三十一章 字符串转换成整数,通配符字符串匹配

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! 第三十~ ...

  7. 字符串转换成整数,带通配符的字符串匹配

    之前本一直想写写神经网络算法和EM算法,但写这两个算法实在需要大段大段的时间,而平时上班,周末则跑去北大教室自习看书(顺便以时间为序,说下过去半年看过的自觉还不错的数学史方面的书:<数理统计学简 ...

  8. 把字符串转换成整数(2014年阿里巴巴实习生招聘面试题)

    题目:写一个strToInt函数,实现字符串str转换成整数num. 如何将字符串转换成整数,本文使用Java列出了三种方法: 1.利用java.lang.Integer类中的静态函数parseInt ...

  9. 程序员编程艺术第三十~三十一章:字符串转换成整数,通配符字符串匹配

    第三十~三十一章:字符串转换成整数,带通配符的字符串匹配 前言 之前本一直想写写神经网络算法和EM算法,但写这两个算法实在需要大段大段的时间,而平时上班,周末则跑去北大教室自习看书(顺便以时间为序,说 ...

最新文章

  1. 重构第28 天 重命名bool方法(Rename boolean method)
  2. springboot2处理跨域
  3. python笔记之function函数
  4. IDEA导入Maven项目,pom.xml文件中 有inspects a maven model for resolution problems报错 !!!!!!!!!!有用
  5. 强调团体与配合的jinbiguandan
  6. 傲游浏览器linux傲游源,Ubuntu下安装遨游浏览器
  7. 【转】CSS transitions#CSS3变换入门
  8. linux 文件大小 自动变化 写,Linux下自动清理超过指定大小文件的方法
  9. 嵌入式行业公司及所属产业
  10. opencv——Mat 矩阵数据类型转换convertTo
  11. 人,越安静,越有力量,心有多静,福有多深
  12. C++核心准则T.61:不要过度参数化成员(SCARY)
  13. android官方转圈圈,android 弹出之后,一直转圈圈??
  14. c语言字符结构数组初始化,C语言结构体数组初始化问题
  15. 大数据技术之 Flume
  16. 从SSD角度学习NAND Flash(一)
  17. 无法下载图片 App Transport Security has blocked a cleartext HTTP (http://) resource load since it is insec
  18. 0xC000005:Access Violation和指针强制转换问题
  19. 判断2-100之间有多少个素数,并输出所有素数
  20. iOS-error: unable to read property list from file: /Users/XX/Info.plist

热门文章

  1. 经过时间考验的成功测试工作实践
  2. Espressif 玩转 SoftAP
  3. Linux int64类型,C++ 中_int64的用法
  4. golang uint 转 int64
  5. 自己关于学习js的一些经历
  6. JAVA多线程:sleep(0)、sleep(1)、sleep(1000)的区别(四)
  7. 苹果授权登陆 服务端验证(java)
  8. 2022-03-30 西安 javaSE(02)基本数据类型转换、自增运算、三元运算符、原反补码位运算
  9. ABAPA实现二维码打印
  10. 概率论复习之关于点估计