leetcode_8

淳属虚构 · · 464 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

Golang:

思路:这题我也不知道为啥我非要在半夜把这道题做出来,而且还非要丧心病狂的去用两种方式解,从而成功拉低了我的提交正确率。。。这题不想多说,这题我第一种代码极烂,完全不推荐大家使用,只是作为一个思路,即使用正则表达式去做这题。

代码如下:

func myAtoi(str string) int {
    reg:=regexp.MustCompile("^\\s*[+-]?0*\\d{1,10}")
    if reg!=nil{
        res:=reg.FindString(str)
        if res=="" {
            return 0
        }else{
            bytes:=[]byte(res)
            i:=0
            for i<len(bytes) {
                if bytes[i]==' '||bytes[i]=='+'{
                    i++
                }else {
                    break
                }
            }
            bytes=bytes[i:]
            bts:=string(bytes)
            result,_:=strconv.Atoi(bts)
            if -2147483648 >result{
                return -2147483648
            }
            if result>2147483647 {
                return 2147483647
            }
            return result
        }
    }
    return 0
}
    

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:淳属虚构

查看原文:leetcode_8

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

464 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传