数据结构-搜索插入位置(二分查找)

思路:

目标数组为升序数组,通过while循环,在第一次循环取中间一半的索引值,比较目标值大于还是小于,若大于则往后继续二分查找,若小于则往前二分查找,while循环结束条件为找到了目标值。

例如:数组为[1,3,5,6],输入目标值为4,则应返回2.

设置2个标志值,firstIndex和lastIndex,分别表示该次循环中的二分查找的索引范围,初始值分别为0以及数组长度-1.

每次二分查找后,比较索引值和目标值大小,如果目标值大于索引值则设置索引值+1为firstIndex,如果小于则设置索引值-1为lastIndex。(之所以+1,-1是为了方便结束循环,只有firstIndex大于lastIndex才认为没有在数组中找到目标值)

如果结束循环方式为firstIndex>lastIndex,则要根据上一次循环中的索引值与目标值的大小判断目标值应该插入到哪个位置,如果目标值小于索引值,则应该插入到索引值处,如果大于则应该插入到索引值后一位处。

代码如下:

    public int SearchInsert(int[] nums, int target)
    {
        int length= nums.Length;
        int i = (length - 1) /2;
        int lastIndex = length-1;
        int firstIndex = 0;
        while (target!= nums[i])
        {
            
            if (nums[i] < target)
            {
                firstIndex = i+1;
            }
            else
            {
                lastIndex = i-1;
            }
            if (firstIndex> lastIndex)
            {
                if (nums[i] > target)
                {
                    return i;
                }
                else
                {
                    return i + 1;
                }
            }
            int offset = (lastIndex - firstIndex) / 2;
            i = firstIndex + offset;
        }
        return i;
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值