二分查找刷题(二)

目录

1.搜索插入位置

算法原理

代码编写

[2.x 的平方根](#2.x 的平方根)

算法原理

代码编写

3.山脉数组的峰顶索引

算法原理


1.搜索插入位置

算法原理

判断二段性

可以将区间分于5和大于等于5的两个区间,可以使用二分查找搜索左区间的模板。

代码编写

cpp 复制代码
int searchInsert(vector<int>& nums, int target) {
        int left = 0,right = nums.size()-1;
        while(left < right)
        {
            int mid = left + (right - left) / 2;
            if(nums[mid] < target)
            {
                left = mid+1;
            }
            else
            {
                right = mid;
            }
        }
        if(target > nums[nums.size()-1])//如果是数组的末尾返回下一个位置
        {
            return nums.size();
        }
        return  right;
    }

2.x 的平方根

算法原理

根据题意小数部分将被舍去

可以将区间分为,小于等于x和大于x的两段区间,可以使用查找左区间的模板。

代码编写

cpp 复制代码
 int mySqrt(int x) {
        long long left = 0,right = x;
        while(left < right)
        {   
            long long mid = left + (right - left + 1)/2;
            if(mid * mid <= x)
            {
                left = mid;
            }
            else 
            {
                right = mid -1;
            }
        }
        return left;
    }

3.山脉数组的峰顶索引

算法原理

可以将区间分为,小于等于山顶和大于山顶的两段区间,可以使用查找右区间的模板

cpp 复制代码
class Solution {
public:
    int peakIndexInMountainArray(vector<int>& arr) {
        int left = 0,right = arr.size()-1;
        while(left < right)
        {
            int mid = left + (right-left)/2;
           if(arr[mid] < arr[mid+1])
           {
               left = mid+1;
           }
           else
           {
               right = mid;
           }
        }
        return left;
    }
};
相关推荐
墨染点香25 分钟前
LeetCode 刷题【126. 单词接龙 II】
算法·leetcode·职场和发展
aloha_7891 小时前
力扣hot100做题整理91-100
数据结构·算法·leetcode
Tiny番茄1 小时前
31.下一个排列
数据结构·python·算法·leetcode
挂科是不可能出现的1 小时前
最长连续序列
数据结构·c++·算法
_Aaron___1 小时前
List.subList() 返回值为什么不能强转成 ArrayList
数据结构·windows·list
前端小L2 小时前
动态规划的“数学之魂”:从DP推演到质因数分解——巧解「只有两个键的键盘」
算法·动态规划
RTC老炮2 小时前
webrtc弱网-ReceiveSideCongestionController类源码分析及算法原理
网络·算法·webrtc
mjhcsp2 小时前
C++ int 类型深度解析:从底层实现到实战应用
c++·int
21号 12 小时前
9.Redis 集群(重在理解)
数据库·redis·算法
码农多耕地呗3 小时前
力扣146.LRU缓存(哈希表缓存.映射+双向链表数据结构手搓.维护使用状况顺序)(java)
数据结构·leetcode·缓存