算法——二分查找(day10)
创始人
2024-11-21 04:04:03
0

目录

69. x 的平方根

题目解析:

算法解析:

代码:

35. 搜索插入位置

题目解析:

算法解析:

代码:


69. x 的平方根

69. x 的平方根 - 力扣(LeetCode)

题目解析:

老规矩,先用暴力算法思考~

我们对从1到x的平方挨个遍历去寻找,如果发现遇到其平方和刚好相等那就返回原位置,如果x刚好卡在两数平方和之间,那就取其前面的。

算法解析:

我们通过暴力可以发现能将所有情况划分为两个区间,一个是平方和小于等于x,代表能得到结果的区间。另一个是平方和大于x的区间,代表无法得到结果的区间。

  • 当mid*mid落入有结果区间时,left紧紧跟住mid即可。
  • 当mid*mid落入无结果区间时,right跳出区间即可。

代码:

class Solution { public:     int mySqrt(int x) {         //特殊情况,特殊处理         if (x < 1) return 0;         int left = 1;         int right = x;         while (left < right)         {             //防止数值溢出             long long mid = left + (right - left + 1) / 2;             if (mid * mid > x)             {                 right = mid - 1;             }             else             {                 left = mid;             }         }         return left;     } };

 

35. 搜索插入位置

35. 搜索插入位置 - 力扣(LeetCode)

题目解析:

这道题一看复杂度就知道要用二分查找了,而关键就在于我们需要找到其二段性。需要划分出有结果的区间与无结果的区间。

算法解析:

何为有结果区间呢?就比如我们找到与target相等的值就会返回其结果,找到比target大的值就意味要插入数组中并返回下标。这两个都是有结果的所以以它们为边界划分区间。

  • 当mid落入有结果区间,left跟紧mid即可。
  • 当mid落入无结果区间,right跳出区间即可。

代码:

class Solution { public:     int searchInsert(vector& nums, int target) {         int left = 0;         int right = nums.size() - 1;          while (left < right)         {             int mid = left + (right - left) / 2;              if (nums[mid] < target)             {                 left = mid + 1;             }             else             {                 right = mid;             }         }         if (nums[right] >= target)         {             return right;         }         //边界情况         else         {             return right + 1;         }     } };

相关内容

热门资讯

一分钟内幕!科乐吉林麻将系统发... 一分钟内幕!科乐吉林麻将系统发牌规律,福建大玩家确实真的是有挂,技巧教程(有挂ai代打);所有人都在...
一分钟揭秘!微扑克辅助软件(透... 一分钟揭秘!微扑克辅助软件(透视辅助)确实是有挂(2024已更新)(哔哩哔哩);1、用户打开应用后不...
五分钟发现!广东雀神麻雀怎么赢... 五分钟发现!广东雀神麻雀怎么赢,朋朋棋牌都是是真的有挂,高科技教程(有挂方法)1、广东雀神麻雀怎么赢...
每日必看!人皇大厅吗(透明挂)... 每日必看!人皇大厅吗(透明挂)好像存在有挂(2026已更新)(哔哩哔哩);人皇大厅吗辅助器中分为三种...
重大科普!新华棋牌有挂吗(透视... 重大科普!新华棋牌有挂吗(透视)一直是有挂(2021已更新)(哔哩哔哩)1、完成新华棋牌有挂吗的残局...
二分钟内幕!微信小程序途游辅助... 二分钟内幕!微信小程序途游辅助器,掌中乐游戏中心其实存在有挂,微扑克教程(有挂规律)二分钟内幕!微信...
科技揭秘!jj斗地主系统控牌吗... 科技揭秘!jj斗地主系统控牌吗(透视)本来真的是有挂(2025已更新)(哔哩哔哩)1、科技揭秘!jj...
1分钟普及!哈灵麻将攻略小,微... 1分钟普及!哈灵麻将攻略小,微信小程序十三张好像存在有挂,规律教程(有挂技巧)哈灵麻将攻略小是一种具...
9分钟教程!科乐麻将有挂吗,传... 9分钟教程!科乐麻将有挂吗,传送屋高防版辅助(总是存在有挂)1、完成传送屋高防版辅助透视辅助安装,帮...
每日必看教程!兴动游戏辅助器下... 每日必看教程!兴动游戏辅助器下载(辅助)真是真的有挂(2025已更新)(哔哩哔哩)1、打开软件启动之...