当前位置: 首页 > news >正文

69. x 的平方根


文章目录

  • 1.题目
  • 2.思路
  • 3.代码


1.题目

69. x 的平方根

给你一个非负整数 x ,计算并返回 x算术平方根

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

**注意:**不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5

示例 1:

输入:x = 4
输出:2

示例 2:

输入:x = 8
输出:2
解释:8 的算术平方根是 2.82842..., 由于返回类型是整数,小数部分将被舍去。

2.思路

  1. 初始化左边界 left 为 0,右边界 rightx,用于定义搜索范围。
  2. 通过二分查找的方式,计算中间值 mid,并求出 mid 的平方 square
  3. 如果 square 等于 x,直接返回 mid,因为它就是 x 的整数平方根。
  4. 如果 square 大于 x,说明当前的 mid 太大,更新右边界 right = mid - 1,继续在较小的范围内搜索。
  5. 如果 square 小于 x,说明当前的 mid 太小,更新左边界 left = mid + 1,继续在较大的范围内搜索。
  6. 当搜索结束时,返回 right,它是平方小于或等于 x 的最大整数,即 x 的整数平方根。

3.代码

class Solution {
public:int mySqrt(int x) {long long  left = 0, right = x;while(left<=right){long long mid = left+(right-left)/2;long long square  = mid*mid;if(square == x){return mid;}else if(square>x){right = mid-1;}else{left = mid+1;}}return right;}
};


http://www.mrgr.cn/news/43217.html

相关文章:

  • 计算机网络:物理层 —— 物理层概述
  • java目录总结
  • 平衡二叉搜索树之 AVL 树的模拟实现【C++】
  • java基础知识点
  • Spring Boot大学生就业招聘系统的架构与实现
  • 6个解决找不到msvcr100.dll,无法继续执行代码的方法
  • C语言指针plus版练习
  • 0.计网和操作系统
  • 深入理解 JavaScript 事件循环机制:单线程中的异步处理核心
  • 【Linux】wsl虚拟机时间和实际时间不符合
  • LeetCode题练习与总结:H 指数 Ⅱ--275
  • Spring Boot服务性能优化策略及代码示例
  • OpenVINO基本操作流程
  • Docker实践与应用举例
  • Java反射、自定义注解Demo
  • 【计算复杂性理论】P可归约(归约,P-reducible)与P、NP、NP-Hard、NP-Complete问题
  • 【AI知识点】伯努利试验(Bernoulli trial)(两点分布、0-1分布)
  • 3.资源《Arduino UNO R3 proteus 电机测速仿真工程文件(含驱动代码)》说明。
  • 自然语言处理(NLP):用Python进行情感分析的深入探索
  • C++11新特性(基础)【2】