力扣-35.搜索插入位置

题目描述

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

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

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

小结:第一个注意low=high要进循环,第二个注意找不到返回low,至于为什么我也想了很久,经过多次尝试,当循环结束时,low正好移动到了第一个大于等于target的位置。

相关推荐
轻抚酸~11 小时前
KNN(K近邻算法)-python实现
python·算法·近邻算法
Yue丶越13 小时前
【C语言】字符函数和字符串函数
c语言·开发语言·算法
小白程序员成长日记13 小时前
2025.11.24 力扣每日一题
算法·leetcode·职场和发展
有一个好名字13 小时前
LeetCode跳跃游戏:思路与题解全解析
算法·leetcode·游戏
AndrewHZ14 小时前
【图像处理基石】如何在图像中提取出基本形状,比如圆形,椭圆,方形等等?
图像处理·python·算法·计算机视觉·cv·形状提取
蓝牙先生14 小时前
简易TCP C/S通信
c语言·tcp/ip·算法
2501_9418705615 小时前
Python在高并发微服务数据同步与分布式事务处理中的实践与优化
leetcode
xiaoye-duck16 小时前
计数排序:高效非比较排序解析
数据结构
2501_9411477117 小时前
高并发微服务架构Spring Cloud与Dubbo在互联网优化实践经验分享
leetcode
稚辉君.MCA_P8_Java18 小时前
Gemini永久会员 Java中的四边形不等式优化
java·后端·算法