题目String to Integer (atoi)(难度Medium)

大意是找出给定字串开头部分的整型数值,忽略开头的空格,注意符号,对超出Integer的数做取边界值处理。

方案1

 class Solution {
     fun myAtoi(str: String): Int {
         val maxInt = "
         val maxIntS = "+2147483647"
         val minIntS = "-2147483648"
         val lengthMI = maxInt.length
         val lengthMIS = maxIntS.length
         var result = ""
         var strR = str.trim()

         //strR为空
         if (strR.isEmpty()) {

         }

         //strR不为空,且不以+/-开头
         ] && ]) {
             //不以数字开头
             ].isDigit()) {

             }

             //以数字开头
             for (c in strR) {
                 if (c.isDigit()) {
                     result += c
                 } else {
                     break
                 }
             }
             if (result.length > lengthMI ||
                     (result.length == lengthMI && result > maxInt)) {
                 result = maxInt
             }
             return result.toInt()
         }

         //strR以+/-开头
         //后不是跟数字
          || (strR.length >  && !strR[].isDigit())) {

         }

         //后跟数字
         result += strR[]
         , strR.length)) {
             if (c.isDigit()) {
                 result += c
             } else {
                 break
             }
         }
         ] == '+' && (result.length > lengthMIS ||
                 (result.length == lengthMIS && result > maxIntS))) {
             result = maxIntS
         } ] == '-' && (result.length > lengthMIS ||
                 (result.length == lengthMIS && result > minIntS))) {
             result = minIntS
         }
         return result.toInt()
     }
 }

将数字及其长度这种常量抽象出来,不至于代码中充斥着一丢重复的数字和长度计算,争取在平时的编码过程中养成好习惯。

说到习惯,代码中还有一点提一下,在对字串进行符号存在性、符号后字符等多种情况的判断时并没有使用一长串的if..else..,而是每个小分支直接用return终止。这样的好处是代码可读性与可维护性强,编码过程中不会因分支过多而可能搞混或出现漏处理的情况。

代码先用trim()将字串开头的空字符去除(如果存在的话),然后对有/无符号、是否紧跟数字等多种情况做了清晰的判断和相应的处理。

LeetCode提交详情

从上图看,总共测试了1047个数据,耗时582ms。

测试代码:

 fun main(args: Array<String>) {
     val start = System.currentTimeMillis()
     println(Solution().myAtoi("-0000000000000000006666666bb6aa"))
     val end = System.currentTimeMillis()
     println(end - start)
 }

测试数据

这篇文章先不看算法的耗时,重点关注用于测试的数据。

根据题目的描述,给定字串中应该是可以包含任意字符的,需要我们用代码进行处理,输出要求的结果。

那么,来看几组测试字串及其输出结果:

"   +0aa",0,返回正确的数值0

"   +066bb6aa",66

"   -06 6bb6aa",-6

"   -06666666666666666666bb6aa",-2147483648,数值向下越界

"06666666666666666666bb6aa",2147483647,数值向上越界

"0000000000000000006666666bb6aa",2147483647,???错误的结果,应该是6666666

"a0000000066bb6aa",0,不以符号或数字开头,直接返回0

"- 0000000066bb6aa",0,符号后跟的不是数字,直接返回0

结果分析

可以看到,除了打问号的那一组测试案例,其他均得到了符号要求的结果。即对于不满足要求的字串直接返回0,字串开头的空字符不应影响结果,获取数据过程中遇到非数字立马终止等。

由于题目的描述中并没有具体指明测试字串会是什么样,也没有针对开头很多0的情况进行说明,虽然提交后是accepted状态,但为了算法的严谨性,还是需要对上面出错的情况做进一步的处理。

方案2

 class Solution {
     fun myAtoi(str: String): Int {
         val maxInt = "
         val maxIntS = "+2147483647"
         val minIntS = "-2147483648"
         val lengthMI = maxInt.length
         val lengthMIS = maxIntS.length
         var result = ""
         var strR = str.trim()

         //strR为空
         if (strR.isEmpty()) {

         }

         //strR不为空,且不以+/-开头
         ] && ]) {
             //不以数字开头
             ].isDigit()) {

             }

             //以数字开头
             for (c in strR) {
                 if (c.isDigit()) {
                     result += c
                 } else {
                     break
                 }
             }
              && result[] == ') {
                 result = result.removeRange(, )
             }
             if (result.length > lengthMI ||
                     (result.length == lengthMI && result > maxInt)) {
                 result = maxInt
             }
             return result.toInt()
         }

         //strR以+/-开头
         //后不是跟数字
          || (strR.length >  && !strR[].isDigit())) {

         }

         //后跟数字
         result += strR[]
         , strR.length)) {
             if (c.isDigit()) {
                 result += c
             } else {
                 break
             }
         }
          && result[] == ') {
             result = result.removeRange(, )
         }
         ] == '+' && (result.length > lengthMIS ||
                 (result.length == lengthMIS && result > maxIntS))) {
             result = maxIntS
         } ] == '-' && (result.length > lengthMIS ||
                 (result.length == lengthMIS && result > minIntS))) {
             result = minIntS
         }
         return result.toInt()
     }
 }

代码第31-33及56-58行,其实就是针对数据开头的0进行了移除(当然数据只有一个数字且为0是要保留的),因为开头0的存在不会影响数据的大小,反而会干扰字串的长度计算。测试结果:

"-0000000000000000006666666bb6aa",-6666666

Kotlin实现LeetCode算法题之String to Integer (atoi)的更多相关文章

  1. LeetCode算法题-Rotate String(Java实现)

    这是悦乐书的第317次更新,第338篇原创 在开始今天的算法题前,说几句,今天是世界读书日,推荐两本书给大家,<终身成长>和<禅与摩托车维修艺术>,值得好好阅读和反复阅读. 0 ...

  2. LeetCode算法题-Repeated String Match(Java实现)

    这是悦乐书的第289次更新,第307篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第156题(顺位题号是686).给定两个字符串A和B,找到A必须重复的最小次数,使得B是 ...

  3. LeetCode算法题-Construct String from Binary Tree(Java实现)

    这是悦乐书的第273次更新,第288篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第141题(顺位题号是606).构造一个字符串,该字符串由二叉树中的括号和整数组成,并具 ...

  4. LeetCode算法题-Reverse String II(Java实现)

    这是悦乐书的第256次更新,第269篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第123题(顺位题号是541).给定一个字符串和一个整数k,你需要反转从字符串开头算起的 ...

  5. LeetCode算法题-Reverse String(Java实现)

    这是悦乐书的第205次更新,第217篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第73题(顺位题号是344).编写一个以字符串作为输入并返回字符串的函数.例如: 输入: ...

  6. LeetCode算法题-Backspace String Compare(Java实现)

    这是悦乐书的第327次更新,第350篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第197题(顺位题号是844).给定两个字符串S和T,如果两个字符串都输入到空文本编辑器 ...

  7. LeetCode【8】. String to Integer (atoi) --java实现

    String to Integer (atoi) Implement atoi to convert a string to an integer. Hint: Carefully consider ...

  8. Kotlin实现LeetCode算法题之Two Sum

    LeetCode介绍 LeetCode是算法练习.交流等多功能网站,感兴趣的同学可以关注下(老司机请超车).页面顶部的Problems菜单对应算法题库,附带历史通过滤.难易程度等信息. 未来计划 打算 ...

  9. Kotlin实现LeetCode算法题之Median of Two Sorted Arrays

    题目Median of Two Sorted Arrays(难度Hard) 方案1,数组合并&排序调用Java方法 import java.util.* class Solution { fu ...

随机推荐

  1. 初入APP(结合mui框架进行页面搭建)

      前  言 博主最近在接触移动APP,学习了几个小技巧,和大家分享一下. 1. 状态栏设置 现在打开绝大多数APP,状态栏都是与APP一体,不仅美观,而且与整体协调.博主是个中度强迫症患者,顶部那个 ...

  2. php中常用的字符串长度函数strlen()与mb_strlen()实例解释

    int strlen ( string $string )  int strlen ( string $string )  获取给定字符串的[字节]长度 成功则返回字符串$string的长度,如果$s ...

  3. Django进阶篇【1】

    注:本篇是Django进阶篇章,适合人群:有Django基础,关于Django基础篇,将在下一章节中补充! 首先我们一起了解下Django整个请求生命周期: Django 请求流程,生命周期: 路由部 ...

  4. 集群提交spark任务命令

    >>spark-submit --class WordCount  DataMining.jar /dept_ana/part-00000 /dept_ana/output/wordCou ...

  5. cellForItemAtIndexPath没有调用

    前几天碰到cellForItemAtIndexPath这个数据源方法没有被调用.这是一个collectionView返回cell(item)的数据源方法. 它没有被调用的原因有下: 1.没有设置del ...

  6. web前端面试官挖的那些坑(js)

    题目1: function Foo() { getName = function () { alert (1); }; return this; } Foo.getName = function () ...

  7. es6零基础学习之构建脚本(二)

    编译器打开你的es6项目 首先:创建我们的第一个脚本,tasks/util/args.js      在文件里面要先引入一个包,处理命令行参数 import yargs from 'yargs'; / ...

  8. dotweb框架之旅 [二] - 常用对象-App(dotweb)

    dotweb属于一个Web框架,希望通过框架行为,帮助开发人员快速构建Web应用,提升开发效率,减少不必要的代码臃肿. dotweb包含以下几个常用对象: App(dotweb) App容器,为Web ...

  9. Echarts数据可视化grid直角坐标系(xAxis、yAxis),开发全解+完美注释

    全栈工程师开发手册 (作者:栾鹏) Echarts数据可视化开发代码注释全解 Echarts数据可视化开发参数配置全解 6大公共组件详解(点击进入): title详解. tooltip详解.toolb ...

  10. DevOps之服务故障

    唠叨话 关于德语噢屁事的知识点,仅提供精华汇总,具体知识点细节,参考教程网址,如需帮助,请留言. <DevOps服务故障> 0.故障1.设施故障2.设备故障3.系统故障4.虚拟化故障5.存 ...