前端与算法 leetcode 8. 字符串转换整数 (atoi)


题目描述

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

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

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

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

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

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

说明:

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

示例 1:

  1. 输入: "42"
  2. 输出: 42

示例 2:

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

示例 3:

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

示例 4:

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

示例 5:

  1. 输入: "-91283472332"
  2. 输出: -2147483648
  3. 解释: 数字 "-91283472332" 超过 32 位有符号整数范围。
  4.   因此返回 INT_MIN (−231)

8. 字符串转换整数 (atoi)

概要

手搓一个api

提示

循环

解析

解法一:正则

字符串去除空格然后正则匹配以-+开头数字结束的部分

解法二:api

直接parseint,判断一下即可

解法二:手搓一个api

这个办法通用性要高很多清除空格然后判断首位是否是数字,先实现js版本击败80%,随后在java上实现2ms,击败99%

算法

java解法

  1. class Solution {
  2. public int myAtoi(String str) {
  3. if(str.isEmpty()) return 0 ;
  4. char[] req = str.toCharArray();
  5. long res = 0;
  6. int i=0,s=1,n=str.length();
  7. while(i<n&&req[i]==' '){i++;}
  8. if(i<n && req[i]=='+'){i++;}
  9. else if(i<n&&req[i]=='-'){i++;s=-1;}
  10. while(i<n&&(req[i]>='0'&&req[i]<='9')){
  11. if(res!=(int)res){
  12. return (s==1)?Integer.MAX_VALUE:Integer.MIN_VALUE;
  13. }
  14. res=res*10+req[i++]-'0';
  15. }
  16. if(res!=(int)res){
  17. return (s==1)?Integer.MAX_VALUE:Integer.MIN_VALUE;
  18. }
  19. return (int)(res*s);
  20. }
  21. }

js解法

  1. /**
  2. * @param {string} str
  3. * @return {number}
  4. */
  5. var myAtoi = function (str) {
  6. const result = str.trim().match(/^(-|\+)?\d+/g);
  7. return result? Math.max(Math.min(Number(result[0]), 2 ** 31 - 1), -(2 ** 31)): 0;
  8. // 一行代码解决问题
  9. // return parseInt(str, 10) < -(2 ** 31) ? -(2 ** 31) : (parseInt(str, 10) > (2 ** 31) - 1 ? (2 ** 31) - 1 : ((parseInt(str, 10) >= -(2 ** 31) && parseInt(str, 10) <= (2 ** 31) - 1) ? parseInt(str, 10) : 0));
  10. // 正经点的api侠解答
  11. // let result = parseInt(str, 10);
  12. // let max = 2 ** 31;
  13. // if (Number.isNaN(result)) {
  14. // return 0;
  15. // } else if (result < 0 - max) {
  16. // return 0 - max;
  17. // } else if (result > max - 1) {
  18. // return max - 1;
  19. // } else {
  20. // return result;
  21. // }
  22. // 不调api的解法
  23. // str = str.trim(); // 清除空格
  24. // let max = 2 ** 31;
  25. // // 如果不是数字
  26. // if (!(str.charCodeAt(0) >= 48 && str.charCodeAt(0) <= 57)) {
  27. // if (str.charAt(0) === '+') {
  28. // let req = res(str, 1);
  29. // return req >= (max - 1) ? max - 1 : req;
  30. // }
  31. // if (str.charAt(0) === '-') {
  32. // let req = -(res(str, 1));
  33. // return req <= -max ? -max : req;
  34. // }
  35. // } else {
  36. // // 第一位就是数字的情况
  37. // let req = res(str, 0);
  38. // return req >= (max - 1) ? max - 1 : req;
  39. // }
  40. // return 0;
  41. // };
  42. // // 解析数字,第一个参数字符串,第二个起始位置
  43. // const res = (s, num) => {
  44. // let r = 0;
  45. // for (let i = num; i < s.length; i++) {
  46. // // 只接受数字
  47. // if (s.charCodeAt(i) <= 57 && s.charCodeAt(i) >= 48) {
  48. // r = r * 10 + (s.charCodeAt(i) - 48);
  49. // } else {
  50. // break;
  51. // }
  52. // }
  53. // // 最大值和最小值之间有差距,在这里判断不如结束后判断
  54. // return r;
  55. };

传入测试用例的运行结果

  1. input:
  2. output:

执行结果

  1. 执行用时 :80 ms, 在所有 javascript 提交中击败了94.84%的用户
  2. 内存消耗 :35.5 MB, 在所有 javascript 提交中击败了74.01%的用户

GitHub仓库

查看github仓库 觉的骚也可以给个星星

查看更多

查看更多题解

前端与算法 leetcode 8. 字符串转换整数 (atoi)的更多相关文章

  1. LeetCode 8. 字符串转换整数 (atoi)(String to Integer (atoi))

    8. 字符串转换整数 (atoi) 8. String to Integer (atoi) 题目描述 LeetCode LeetCode8. String to Integer (atoi)中等 Ja ...

  2. [LeetCode] 8. 字符串转换整数 (atoi)

    题目链接:https://leetcode-cn.com/problems/string-to-integer-atoi/ 题目描述: 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先 ...

  3. 每日一题LeetCode 8. 字符串转换整数 (atoi)

    问题描述 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. 当我们寻找到的第一个非空字符为正或者负号时,则将 ...

  4. LeetCode 8.字符串转换整数 (atoi)(Python3)

    题目: 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. 当我们寻找到的第一个非空字符为正或者负号时,则将该 ...

  5. 前端与算法 leetcode 387. 字符串中的第一个唯一字符

    目录 # 前端与算法 leetcode 387. 字符串中的第一个唯一字符 题目描述 概要 提示 解析 解法一:双循环 解法二:Set法单循环 算法 传入测试用例的运行结果 执行结果 GitHub仓库 ...

  6. Java实现 LeetCode 8 字符串转换整数(atoi)

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

  7. LeetCode Golang 8. 字符串转换整数 (atoi)

    8. 字符串转换整数 (atoi) 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. 当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组 ...

  8. 字符串转换整数 (atoi) C++实现 java实现 leetcode系列(八)

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

  9. 17、字符串转换整数 (atoi)

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

随机推荐

  1. Spring Security 整合JWT(四)

    一.前言 本篇文章将讲述Spring Security 简单整合JWT 处理认证授权 基本环境 spring-boot 2.1.8 mybatis-plus 2.2.0 mysql 数据库 maven ...

  2. Ubuntu 安装mysql & 自定义数据存储目录

    一.安装 apt-get install mysql-server 执行过程如下: root@duke:~# apt-get install mysql-server 正在读取软件包列表... 完成 ...

  3. .Net Core 3.0 IdentityServer4 快速入门

    .Net Core 3.0 IdentityServer4 快速入门 一.简介 IdentityServer4是用于ASP.NET Core的OpenID Connect和OAuth 2.0框架. 将 ...

  4. c使用二叉链表创建二叉树遇到的一些疑问和思考

    二叉链表存储二叉树 学习的时候参考的是<大话数据结构>,书中是这样定义的 typedef char TElemType; typedef struct BiTNode { TElemTyp ...

  5. 使用js json/xml互相转换

    <html> <head> <title>json与xml互转</title> <script type="text/javascrip ...

  6. 玩转OneNET物联网平台之MQTT服务③ —— 远程控制LED(设备自注册)

    授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...

  7. VirtualBox NAT Network配置

    VirtualBox NAT Network配置(OSX上的) VirtualBox的5种连接方式 NAT :虚拟机之间不能互通 NAT网络 :本文对象 桥接 :一般情况下虚拟机无法设置静态IP,并且 ...

  8. Java设计模式之状态模式详解

    (本文由言念小文原创,转载请注明出处) 在实际工作中经常遇到某个对象,处于不同的状态有不同行为逻辑.且状态之间可以相互迁移的业务场景,特别是在开发通信协议栈类软件中尤为多见.<设计模式之禅> ...

  9. Java IO_003.Reader与Writer--字符流以及编码对数据的操作(读取与写入)

    Java IO之Reader与Writer对象常用操作(包含了编码问题的处理) 涉及到文件(非文件夹)内容的操作,如果是纯文本的情况下,除了要用到File(见之前文章),另外就必须用到字符输入流或字符 ...

  10. Nginx 热部署和日志切割,你学会了吗?

    上篇文章,我们已经安装好 Nginx,并且配置好 Nginx 文件后,这个时候我就需要操作 Nginx 的命令行了,这篇文章主要讲解 Nginx 命令行相关知识,并通过日常遇到的热部署.切割日志文件场 ...