35. 搜索插入位置

题目:

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

请必须使用时间复杂度为 O(log n) 的算法。

示例 1:

复制代码
输入: nums = [1,3,5,6], target = 5
输出: 2

示例 2:

复制代码
输入: nums = [1,3,5,6], target = 2
输出: 1

解法一:

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

解法二:

只要看到题里给出的数组是有序数组,都可以想一想是否可以使用二分法。

java 复制代码
class Solution {
    public int searchInsert(int[] nums, int target) {
        int size = nums.length;
        int slow = 0;
        int fast = size - 1;
        while(slow <= fast){
            int mid = slow + (fast - slow) / 2;
            if (nums[mid] > target){
                fast = mid - 1;
            }else if(nums[mid] < target){
                slow = mid + 1;
            }else{
                return mid;
            }
        }
        return fast + 1;
    }
}
相关推荐
地平线开发者38 分钟前
征程 6M 部署 Omnidet 感知模型
算法·自动驾驶
秋说1 小时前
【PTA数据结构 | C语言版】线性表循环右移
c语言·数据结构·算法
浩瀚星辰20242 小时前
图论基础算法:DFS、BFS、并查集与拓扑排序的Java实现
java·算法·深度优先·图论
JiaJZhong3 小时前
力扣.最长回文子串(c++)
java·c++·leetcode
oioihoii4 小时前
C++随机打乱函数:简化源码与原理深度剖析
开发语言·c++·算法
不知名。。。。。。。。4 小时前
分治算法---快排
算法
minji...4 小时前
数据结构 算法复杂度(1)
c语言·开发语言·数据结构·算法
凌肖战5 小时前
力扣网编程150题:加油站(贪心解法)
算法·leetcode·职场和发展
吃着火锅x唱着歌5 小时前
LeetCode 3306.元音辅音字符串计数2
算法·leetcode·c#
kngines5 小时前
【力扣(LeetCode)】数据挖掘面试题0003: 356. 直线镜像
leetcode·数据挖掘·直线镜像·对称轴