博客
关于我
剑指offer——0到n-1中缺失的数字(二分思维)
阅读量:279 次
发布时间:2019-03-01

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

题目是找出0到n-1中缺失的数字。我们可以通过二分查找的方法来解决这个问题。以下是详细的分析和代码实现:

思路分析

我们需要找出0到n-1范围内缺失的数字。通过分析,我们可以利用二分查找的方法来高效地解决这个问题。具体步骤如下:

  • 初始化边界:左边界l设为0,右边界r设为数组的长度减1。
  • 如果数组中最后一个元素等于右边界r,则说明所有数字都存在,我们需要将右边界r增加1。
  • 进入二分查找循环:计算中间位置mid。
  • 如果数组中mid位置的数字不等于mid,说明缺失的数字在左边或右边。根据具体情况调整边界:
    • 如果nums[mid] < mid,说明缺失的数字在右边,调整右边界r = mid。
    • 否则,调整左边界l = mid + 1。
  • 当左边界l超过右边界r时,结束循环,返回右边界r的值作为缺失的数字。
  • 代码实现

    class Solution {    public int getMissingNumber(vector
    &nums) { if (nums.empty()) { return 0; } int l = 0; int r = nums.size() - 1; if (nums[r] == r) { r++; } while (l < r) { int mid = l + (r - l + 1) / 2; if (nums[mid] != mid) { r = mid; } else { l = mid + 1; } } return r; }}

    总结

    通过上述方法,我们能够高效地找出0到n-1范围内缺失的数字。代码通过二分查找的方法,确保了时间复杂度为O(log n),适用于大数组的情况。

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

    你可能感兴趣的文章
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers实战:判断共享单车是否在电子围栏内
    查看>>
    Openlayers实战:绘制图形,导出geojson文件
    查看>>
    Openlayers实战:绘制图形,导出KML文件
    查看>>
    Openlayers实战:绘制多边形,导出CSV文件
    查看>>
    Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
    查看>>
    Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
    查看>>
    Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
    查看>>
    Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
    查看>>
    Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    Openlayers高级交互(2/20):清除所有图层的有效方法
    查看>>
    Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
    查看>>
    Openlayers高级交互(6/20):绘制某点,判断它是否在一个电子围栏内
    查看>>
    Openlayers高级交互(7/20):点击某点弹出窗口,自动播放视频
    查看>>
    Openlayers高级交互(8/20):选取feature,平移feature
    查看>>
    Openlayers:DMS-DD坐标形式互相转换
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>