【每日LeetCode】35. 搜索插入位置

题目

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

你可以假设数组中无重复元素。

示例 1:

输入: [1,3,5,6], 5
输出: 2
示例 2:

输入: [1,3,5,6], 2
输出: 1
示例 3:

输入: [1,3,5,6], 7
输出: 4
示例 4:

输入: [1,3,5,6], 0
输出: 0

题解

从左到右直接搜索

class Solution {
    public int searchInsert(int[] nums, int target) {
        if(nums == null) return 0;
        int i;
        for(i = 0; i < nums.length; i++){
            if(nums[i] >= target)
                return i;
        }
        return i;
    }
}

细心的同学发现,这道题的标签上还有一个二分查找,其实就是因为有序,所以二分。有序的题目都要想想能不能用二分。

class Solution {
    public int searchInsert(int[] nums, int target) {
        if(nums == null) return 0;
        int low = 0;
        int high = nums.length-1;
        while(low <= high){
            int mid = (low + high) / 2;
            if(nums[mid] == target)
                return mid;
            else if(nums[mid] < target)
                low = mid + 1;
            else
                high = mid - 1;
        }
        return low;
    }
}
image

找工作的同学扫码关注,每天一道面试算法题

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容