leetcode.69.求一个数的平方根

栏目: 编程工具 · 发布时间: 7年前

内容简介:实现 int sqrt(int x) 函数。计算并返回 x 的平方根,其中 x 是非负整数。由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去。

题目描述

实现 int sqrt(int x) 函数。

计算并返回 x 的平方根,其中 x 是非负整数。

由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去。

示例1:

输入: 4
输出: 2

示例2:

输入: 8
输出: 2
说明: 8 的平方根是 2.82842..., 
     由于返回类型是整数,小数部分将被舍去。

暴力版本

// 暴力解法
func mySqrt(x int) int {
    for i := 0; i <= x; i++ {
        res := i * i
        if res == x {
            return i
        } else if res > x {
            return i - 1
        }
    }
    return -1
}

二分查找

//在有序数组中,找到最后一个小于等于给定值的数
func mySqrt2(x int) int {
    low, high := 0, x
    for low <= high {
        //防止大数相加溢出
        //位运算更高效
        mid := low + (high-low)>>1
        product := mid * mid
        if product > x {
            high = mid - 1
        } else {
            if (mid == x) || (mid+1)*(mid+1) > x {
                //遍历最后一个数 || 下一个数大于目标值
                return mid
            }
            //下一个数小于等于目标值,所以mid不是最后一个数
            low = mid + 1
        }
    }
    return -1
}

二分查找思路

  • 相当于从0-x中找到最后一个平方<=x的整数
  • 我们求解的是最后一个小于等于给定值的元素,所以当 product<=x时,需要确认 mid+1 的平方>x
  • 如果 mid+1 的平方 <= x ,说明mid肯定不是最后一个,更新low

GitHub

参考资料

leetcode 69. x 的平方根

极客时间 数据结构与算法之美

本文为原创文章,转载注明出处,欢迎扫码关注公众号 tomorrowwu 或者网站 https://lovecoding.club ,第一时间看后续精彩文章,觉得好的话,顺手分享到朋友圈吧,感谢支持。

leetcode.69.求一个数的平方根


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

计算机系统概论

计算机系统概论

派特(Patt.Y.N.) / 梁阿磊、蒋兴昌、林凌 / 机械工业 / 2008-1-1 / 49.00元

《计算机系统概论(原书第2版)》是计算机科学的经典基础教材。全书以自底向上方法帮助学生理解计算机系统的原理,前半部分阐述了计算机底层结构,后半部分讲解了高级语言编程及编程方法学,主要内容包括数据类型及其运算、数字逻辑、冯·诺伊曼模型、汇编语言、输入和输出、TRAP程序和子程序、C语言编程等内容。 《计算机系统概论(原书第2版)》可用作高等院校计算机及相关专业学生的入门教材,也可作为的计算机专......一起来看看 《计算机系统概论》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

URL 编码/解码
URL 编码/解码

URL 编码/解码