Kotlin实现LeetCode算法题之String to Integer (atoi)
题目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)的更多相关文章
- LeetCode算法题-Rotate String(Java实现)
这是悦乐书的第317次更新,第338篇原创 在开始今天的算法题前,说几句,今天是世界读书日,推荐两本书给大家,<终身成长>和<禅与摩托车维修艺术>,值得好好阅读和反复阅读. 0 ...
- LeetCode算法题-Repeated String Match(Java实现)
这是悦乐书的第289次更新,第307篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第156题(顺位题号是686).给定两个字符串A和B,找到A必须重复的最小次数,使得B是 ...
- LeetCode算法题-Construct String from Binary Tree(Java实现)
这是悦乐书的第273次更新,第288篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第141题(顺位题号是606).构造一个字符串,该字符串由二叉树中的括号和整数组成,并具 ...
- LeetCode算法题-Reverse String II(Java实现)
这是悦乐书的第256次更新,第269篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第123题(顺位题号是541).给定一个字符串和一个整数k,你需要反转从字符串开头算起的 ...
- LeetCode算法题-Reverse String(Java实现)
这是悦乐书的第205次更新,第217篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第73题(顺位题号是344).编写一个以字符串作为输入并返回字符串的函数.例如: 输入: ...
- LeetCode算法题-Backspace String Compare(Java实现)
这是悦乐书的第327次更新,第350篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第197题(顺位题号是844).给定两个字符串S和T,如果两个字符串都输入到空文本编辑器 ...
- LeetCode【8】. String to Integer (atoi) --java实现
String to Integer (atoi) Implement atoi to convert a string to an integer. Hint: Carefully consider ...
- Kotlin实现LeetCode算法题之Two Sum
LeetCode介绍 LeetCode是算法练习.交流等多功能网站,感兴趣的同学可以关注下(老司机请超车).页面顶部的Problems菜单对应算法题库,附带历史通过滤.难易程度等信息. 未来计划 打算 ...
- Kotlin实现LeetCode算法题之Median of Two Sorted Arrays
题目Median of Two Sorted Arrays(难度Hard) 方案1,数组合并&排序调用Java方法 import java.util.* class Solution { fu ...
随机推荐
- Prison Break
Prison Break 时间限制: 1 Sec 内存限制: 128 MB提交: 105 解决: 16[提交][状态][讨论版] 题目描述 Scofild又要策划一次越狱行动,和上次一样,他已经掌 ...
- Array Partition I
Given an array of 2n integers, your task is to group these integers into n pairs of integer, say (a1 ...
- Python自学笔记-map和reduce函数(来自廖雪峰的官网Python3)
感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. Python内 ...
- 翻译连载 | 第 10 章:异步的函数式(下)-《JavaScript轻量级函数式编程》 |《你不知道的JS》姊妹篇
原文地址:Functional-Light-JS 原文作者:Kyle Simpson-<You-Dont-Know-JS>作者 关于译者:这是一个流淌着沪江血液的纯粹工程:认真,是 HTM ...
- springboot scheduled并发配置
本文介绍如何使用springboot的sheduled实现任务的定时调度,并将调度的任务实现为并发的方式. 1.定时调度配置scheduled 1)注册定时任务 package com.xiaoju. ...
- DevOps教程
唠叨话 关于德语关我屁事与靠计算逼哥数据,知识点的教学教程. 先简要搭建知识点框架:后逐步完善知识点内容.(暂时提供知识点,大部分未完善,持续更新中.) 注:第一版本,结束于2017年10月18日.其 ...
- Android 添加水印, 以及屏幕存取
/** * 获取水印 */ try { String s = CustomPreferences.getUserInfo().getAccountNo().substring(7,11); View ...
- Ubuntu安装Jupyter Notebook
一.Jupyter介绍 Jupyter Notebook是一个交互式笔记本,支持运行40多种编程语言.Jupyter Notebook 的本质是一个 Web 应用程序,便于创建和共享文学化程序文档,支 ...
- canvas图表详解系列(4):动态散点图
本章建议学习时间4小时 学习方式:详细阅读,并手动实现相关代码(如果没有canvas基础,需要先学习前面的canvas基础笔记) 学习目标:此教程将教会大家如何使用canvas绘制各种图表,详细分解步 ...
- 如何在 UWP 使用 wpf 的 Trigger
本文需要告诉大家,如何使用 Behaviors 做出 WPF 的 Trigger ,需要知道 UWP 不支持 WPF 的 Trigger . 安装 Behaviors 请使用 Nuget 安装,可以输 ...