Easy!

题目描述:

实现 int sqrt(int x) 函数。

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

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

示例 1:

输入: 4
输出: 2

示例 2:

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

解题思路:

这道题要求平方根,我们能想到的方法就是算一个候选值的平方,然后和x比较大小,为了缩短查找时间,我们采用二分搜索法来找平方根,这里属于之前总结的LeetCode Binary Search Summary 二分搜索法小结(http://www.cnblogs.com/grandyang/p/6854825.html)中的第三类的变形,找最后一个不小于目标值的数,代码如下:

C++解法一:

 1 class Solution {
 2 public:
 3     int mySqrt(int x) {
 4         if (x <= 1) return x;
 5         int left = 0, right = x;
 6         while (left < right) {
 7             int mid = left + (right - left) / 2;
 8             if (x / mid >= mid) left = mid + 1;
 9             else right = mid;
10         }
11         return right - 1;
12     }
13 };

这道题还有另一种解法,是利用牛顿迭代法(https://zh.wikipedia.org/wiki/%E7%89%9B%E9%A1%BF%E6%B3%95),记得高数中好像讲到过这个方法,是用逼近法求方程根的神器,在这里也可以借用一下,可参见http://www.cnblogs.com/AnnieKim/archive/2013/04/18/3028607.html,因为要求x2 = n的解,令f(x)=x2-n,相当于求解f(x)=0的解,可以求出递推式如下:

xi+1=xi - (xi- n) / (2xi) = xi - xi / 2 + n / (2xi) = xi / 2 + n / 2xi = (xi + n/xi) / 2

C++解法二:

 1 class Solution {
 2 public:
 3     int mySqrt(int x) {
 4         if (x == 0) return 0;
 5         double res = 1, pre = 0;
 6         while (abs(res - pre) > 1e-6) {
 7             pre = res;
 8             res = (res + x / res) / 2;
 9         }
10         return int(res);
11     }
12 };

下面也是牛顿迭代法,写法更加简洁一些,注意为了防止越界,声明为长整型。

C++解法三:

 1 class Solution {
 2 public:
 3     int mySqrt(int x) {
 4         long res = x;
 5         while (res * res > x) {
 6             res = (res + x / res) / 2;
 7         }
 8         return res;
 9     }
10 };

转载于:https://www.cnblogs.com/ariel-dreamland/p/9151609.html

LeetCode(69):x 的平方根相关推荐

  1. LeetCode #69 x的平方根 二分查找

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

  2. LeetCode 69. x 的平方根:二分查找法实现自定义的函数:x 的平方根

    LeetCode 69. x 的平方根:二分查找法实现自定义的函数:x 的平方根 题目描述 实现 int sqrt(int x) 函数. 计算并返回 x 的平方根,其中 x 是非负整数. 由于返回类型 ...

  3. LeetCode - 69. x 的平方根

    69. x 的平方根 class Solution {private static final Integer MAX_POW = 46340;/*** 牛顿迭代* f(x) = x^2 - n* 切 ...

  4. LeetCode 69. x 的平方根(二分查找)

    文章目录 1. 题目 2.解题 2.1 二分查找 2.2 牛顿迭代 1. 题目 实现 int sqrt(int x) 函数. 计算并返回 x 的平方根,其中 x 是非负整数. 由于返回类型是整数,结果 ...

  5. LeetCode——69 x的平方根

    问题描述: 实现 int sqrt(int x) 函数.计算并返回 x 的平方根,其中 x 是非负整数.由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去. 示例 1: 输入: 4 输出: 2 ...

  6. Leetcode 69 x的平方根 (每日一题 20210805)

    实现 int sqrt(int x) 函数.计算并返回 x 的平方根,其中 x 是非负整数.由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去.示例 1:输入: 4 输出: 2 示例 2:输入 ...

  7. leetcode 69. x 的平方根(C语言)

    题目 实现 int sqrt(int x) 函数. 计算并返回 x 的平方根,其中 x 是非负整数. 由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去. 示例 1: 输入: 4 输出: 2 ...

  8. LeetCode 69 X的平方根

    原题 解题思路:二分法 class Solution { public:int mySqrt(int x) {long long i=0;long long j=x/2+1;//x的平方根不大于x/2 ...

  9. leetcode 69. x 的平方根 思考分析

    题目 实现 int sqrt(int x) 函数. 计算并返回 x 的平方根,其中 x 是非负整数. 由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去. 示例 1: 输入: 4 输出: 2 ...

  10. LeetCode 69 x 的平方根

    题目描述 实现 int sqrt(int x) 函数. 计算并返回 x 的平方根,其中 x 是非负整数. 由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去. 题解 使用二分查找. 代码 cl ...

最新文章

  1. Github最强算法刷题笔记.pdf
  2. mysql 去掉复合索引_MySQL性能优化[实践篇]-复合索引实例
  3. 使用TESSERACT来识别字符
  4. javascript中es6语法
  5. 机器学习如何用于芯片系统设计?《机器学习系统芯片设计》
  6. 微信+php++证书,php - 微信的商户证书文件怎么用
  7. Vue 在beaforeCreate时获取data中的数据
  8. 怎么辨别iPhone手机的真伪?
  9. 2016年开源软件排名TOP50,最受IT公司欢迎的50款开源软件
  10. 美团BERT的探索和实践
  11. 某宝双十一自动养猫,解放你的双手得喵币
  12. 【CSS】三行实现一个黑白网格背景(渐变)
  13. 【设计模式】结构型模式之代理模式
  14. 【移动端聊天功能模板】Vue实现H5聊天系统,实现上下固定中间滚动布局,微信授权功能,自动滚动到底部【详细注释,一看就会】
  15. JS课程分享(7.函数)
  16. 如何驯服事件驱动的微服务
  17. 软件测试工程师Linux笔试题及答案(三)
  18. NOTES邮箱打不开,提示打开的文件出错(打开的文件时出错)。
  19. 基于OpenCV与MFC的大家来找茬外挂[升级版]
  20. jqweui 正在加载样式的用法

热门文章

  1. Android中使用Handler和异步任务(AsyncTack)来为UI线程执行费时操作
  2. [摘]一张图 , oracle merge用法:
  3. python字符串单个替换_如何用变量替换列表中的单个字符串?
  4. 如何使用 Kubernetes 监测定位慢调用
  5. 围观|第一代云原生企业米哈游如何让想象发生?
  6. SpringCloud 应用在 Kubernetes 上的最佳实践 —— 开发篇
  7. java发送get请求_如何快速掌握Java技术 Tomcat知识点有哪些
  8. mysql维护 运维_MySQL运维之--日常维护操作
  9. java creat uid_关于uniqueidentifier:如何在Java中创建唯一ID?
  10. 组合筛选vue_Vue 3 组合式API介绍