二分查找类型算法

今天开始刷题啦,坚持住哟!

使用二分法的前提是数组有序且无重复元素。

704.二分查找

第一遍代码如下:

java 复制代码
class Solution {
    public int search(int[] nums, int target) {
        int left=0;
        int right=nums.length-1;
        while(left<=right){
            int mid = (right-left)/2;
            if (nums[mid]>target){
                right=mid-1;
            }else if(nums[mid]<target){
                left=mid+1;
            }else if(nums[mid]==target){
                return mid;
            }
        }
        return -1;
    }
}

存在错误:

  1. 没有考虑target小于nums[0]和大于nums[length-1]

  2. mid计算错误,且没有防止溢出,以下是两种正确写法

java 复制代码
int mid = left + ((right - left) / 2);
java 复制代码
int mid = left + ((right - left) >> 1);

第二遍代码如下:

java 复制代码
class Solution {
    public int search(int[] nums, int target) {
        if (target < nums[0] || target > nums[nums.length - 1]) {
            return -1;
        }
        int left=0;
        int right=nums.length-1;
        while(left<=right){
            int mid = left+((right-left)/2);
            if (nums[mid]>target){
                right=mid-1;
            }else if(nums[mid]<target){
                left=mid+1;
            }else if(nums[mid]==target){
                return mid;
            }
        }
        return -1;
    }
}

测试通过!

35.搜索插入位置

第一遍代码:

java 复制代码
class Solution {
    public int searchInsert(int[] nums, int target) {
        int left = 0;
        int right = nums.length-1;
        while(left<=right){
            int mid = left + ((right - left)/2);
            if (nums[mid]==target){
                return mid;
            }else if(nums[mid]>target){
                right = mid -1;
            }else{
                left=mid+1;
            }
        }
        return right+1;
    }
}

测试通过!

相关推荐
你知道网上冲浪吗12 分钟前
【原创理论】Stochastic Coupled Dyadic System (SCDS):一个用于两性关系动力学建模的随机耦合系统框架
python·算法·数学建模·数值分析
地平线开发者2 小时前
征程 6 | PTQ 精度调优辅助代码,总有你用得上的
算法·自动驾驶
Tisfy2 小时前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
CoovallyAIHub3 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉
huangzixuan10073 小时前
08.18总结
算法·深度优先·图论
liang_jy3 小时前
数组(Array)
数据结构·面试·trae
逆向菜鸟3 小时前
【摧毁比特币】椭圆曲线象限细分求k-陈墨仙
python·算法
DolphinDB3 小时前
DolphinDB 回测插件快速上手
算法
利刃大大3 小时前
【动态规划:路径问题】最小路径和 && 地下城游戏
算法·动态规划·cpp·路径问题
武大打工仔4 小时前
用 Java 复现哲学家就餐问题
算法