博客
关于我
【LeetCode(Java) - 34】在排序数组中查找元素的第一个和最后一个位置
阅读量:57 次
发布时间:2019-02-25

本文共 1370 字,大约阅读时间需要 4 分钟。

文章目录

1、题目描述

在这里插入图片描述

2、解题思路

  定义一个方法,该方法的功能是找出 target 在 nums 数组中的开始位置或者结束位置,该方法有一个参数 left,该参数为 true 时返回的时开始位置,false 时返回的是结束位置。

  因为题目不保证 nums 数组一定存在 target,因此搜索区间为左开右闭,即初始时:左边界 lo = 0;右边界 hi = nums.length。

  查找开始位置时:

  1、如果 nums[mid] 大于 target,不用说,直接更新右边界为 mid;

  2、当 nums[mid] == target 时,因为 nums[mid] 可能就是开始位置,于是更新右边界为 mid;

  3、当结束 while 循环时,此时 lo == hi,因此直接返回 lo 即可。

  查找结束位置时:

  1、如果 nums[mid] 大于 target,同样直接更新右边界为 mid;

  2、如果 nums[mid] 等于 target,nums[mid] 同样有可能就是结束位置,于是更新左边界为 mid + 1;

  在求结束位置时,返回的值是右边界的下一位,因此要进行减一操作。

  也可以把求开始位置和结束位置拆开成两个方法,更为直观。

3、解题代码

class Solution {       private int extremeInsertionIndex(int[] nums, int target, boolean left) {           int lo = 0;        int hi = nums.length;        while (lo < hi) {               int mid = lo + (hi - lo) / 2;            if (nums[mid] > target || (left && target == nums[mid])) {                   hi = mid;            } else {                   lo = mid + 1;            }        }        return lo;    }    public int[] searchRange(int[] nums, int target) {           int[] targetRange = {   -1, -1};        int leftIdx = extremeInsertionIndex(nums, target, true);        if (leftIdx == nums.length || nums[leftIdx] != target) {               return targetRange;        }        targetRange[0] = leftIdx;        targetRange[1] = extremeInsertionIndex(nums, target, false) - 1;        return targetRange;    }}

转载地址:http://mwq.baihongyu.com/

你可能感兴趣的文章
NIO笔记---上
查看>>
NIO蔚来 面试——IP地址你了解多少?
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
NISP国家信息安全水平考试,收藏这一篇就够了
查看>>
NIS服务器的配置过程
查看>>
NIS认证管理域中的用户
查看>>
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>
NiuShop开源商城系统 SQL注入漏洞复现
查看>>
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLog类库使用探索——详解配置
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 模型中的偏差和公平性检测
查看>>
Vue3.0 性能提升主要是通过哪几方面体现的?
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>
NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
查看>>
NLP、CV 很难入门?IBM 数据科学家带你梳理
查看>>
NLP三大特征抽取器:CNN、RNN与Transformer全面解析
查看>>
NLP入门(六)pyltp的介绍与使用
查看>>
NLP学习笔记:使用 Python 进行NLTK
查看>>