栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

最强解析面试题:x 的平方根(Sqrt(x))

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

最强解析面试题:x 的平方根(Sqrt(x))

文章目录
  • 最强解析面试题:x 的平方根(Sqrt(x))
    • 题目
    • 示例
    • 思路
        • 代码
    • 附录

最强解析面试题:x 的平方根(Sqrt(x))

文章讲解 “ x 的平方根(Sqrt(x)) ” 经典面试题,包含思路及源码,及解惑!

题目

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

示例

输入: 4
输出: 2

思路

二分法

代码
package main

import (
"fmt"
)

func main() {
   fmt.Println("hello https://tool.lu/", Sqrt(0))
   fmt.Println("hello https://tool.lu/", Sqrt(1))
   fmt.Println("hello https://tool.lu/", Sqrt(2))
   fmt.Println("hello https://tool.lu/", Sqrt(4))
   fmt.Println("hello https://tool.lu/", Sqrt(8))
}
func Sqrt(x int) int {
   l, r, mid := 0, x+1, 0
   for l < r {
      mid = (l + r) >> 1
      if mid*mid < x {
         l = mid + 1
      } else {
         r = mid
      }
   }
   return l - 1
}
附录

自负和自大真的是搞笑!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/677720.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号