35.搜索插入位置

题目描述

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

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

示例 1:

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

示例 2:

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

示例 3:

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

提示:

  • 1 <= nums.length <= 104
  • -104 <= nums[i] <= 104
  • nums无重复元素升序排列数组
  • -104 <= target <= 104

题解

java 复制代码
class Solution {
    public int searchInsert(int[] nums, int target) {
     int low=0;
     int high=nums.length-1;
     int mid=0;
     while(low<=high){
        mid=(low+high)/2;
        if(nums[mid]==target) return mid;
        else if(nums[mid]>target) high=mid-1;
        else if(nums[mid]<target) low=mid+1;
     }
     return low;
    }
}
相关推荐
Starry_hello world37 分钟前
双链表(纯代码)
数据结构·笔记·有问必答
luthane39 分钟前
python 实现rayleigh quotient瑞利商算法
开发语言·python·算法
Jcqsunny1 小时前
[dp] 小信走迷宫
算法·前缀和·动态规划·dp
鱼跃鹰飞1 小时前
Leecode热题100-48.旋转图像
java·后端·算法·leetcode·面试
luthane1 小时前
python 实现knapsack背包问题算法
开发语言·python·算法
single5941 小时前
【优选算法】(第十五篇)
java·数据结构·c++·vscode·算法·leetcode
小林熬夜学编程1 小时前
【Linux系统编程】第二十六弹---彻底掌握文件I/O:C/C++文件接口与Linux系统调用实践
java·linux·服务器·c语言·c++·算法
罗勇军1 小时前
《蓝桥杯算法入门》(C/C++、Java、Python三个版本)24年10月出版
java·c语言·python·算法·蓝桥杯
丹柒七2 小时前
力扣刷题之2306.公司命名
c语言·数据结构·算法·leetcode
nick98762 小时前
信号处理之中值滤波
人工智能·算法·信号处理