题目信息

  • 时间: 2019-07-04

  • 题目链接:Leetcode

  • tag:二分查找 哈希表

  • 难易程度:简单

  • 题目描述:

    统计一个数字在排序数组中出现的次数。

示例1:

输入: nums = [5,7,7,8,8,10], target = 8
输出: 2

示例2:

输入: nums = [5,7,7,8,8,10], target = 6
输出: 0

注意

1. 0 <= 数组长度 <= 50000

解题思路

本题难点

排序数组中查找数字,性能最优。

具体思路

排序数组中的搜索问题,首先想到 二分法 解决。

排序数组 nums 中的所有数字 target 形成一个窗口,记窗口的 左 / 右边界 索引分别为 left 和 right ,分别对应窗口左边 / 右边的首个元素。

统计数字 target 的出现次数,可转化为:使用二分法分别找到 左边界 left 和 右边界 right ,易得数字 target 的数量为 right−left−1 。

  • 计算中点 m=(i+j)/2(向下取整)
  • 若 nums[m]<target ,则 target 在闭区间 [m+1,j] 中,因此执行 i=m+1;
  • 若 nums[m]>target ,则 target 在闭区间 [i,m−1] 中,因此执行 j=m−1;
  • 若 nums[m]=target ,则右边界 right 在闭区间 [m+1,j] 中;左边界 left 在闭区间 [i,m−1] 中。
    • 若查找 右边界 right ,则执行 i=m+1 ;(跳出时 i指向右边界)
    • 若查找 左边界 left ,则执行 j=m−1 ;(跳出时 j指向左边界)

提示:查找完右边界后,可用 nums[j]=j 判断数组中是否包含 target ,若不包含则直接提前返回 0 ,无需后续查找左边界。查找完右边界后,左边界 left一定在闭区间 [0,j] 中,因此直接从此区间开始二分查找即可。

代码

class Solution {
public int search(int[] nums, int target) {
// 搜索右边界 right
int i = 0, j = nums.length - 1;
while(i <= j) {
int m = (i + j) / 2;
if(nums[m] <= target) i = m + 1;
else j = m - 1;
}
int right = i;
// 若数组中无 target ,则提前返回
if(j >= 0 && nums[j] != target) return 0;
// 搜索左边界 right
i = 0;
while(i <= j) {
int m = (i + j) / 2;
if(nums[m] < target) i = m + 1;
else j = m - 1;
}
int left = j;
return right - left - 1;
}
}

复杂度分析:

  • 时间复杂度 O(logN) : 二分法为对数级别复杂度。
  • 空间复杂度 O(1) :几个变量使用常数大小的额外空间。

其他优秀解答

解题思路

直接遍历排序数组,计数。

代码

class Solution {
public int search(int[] nums, int target) {
int count = 0;
for(int num : nums){
if(num == target){
count++;
}
}
return count;
}
}

最新文章

  1. Poj The xor-longest Path 经典题 Trie求n个数中任意两个异或最大值
  2. PHP学习笔记:利用gd库给图片打图片水印
  3. 163免费邮客户端设置的POP3、SMTP、IMAP地址
  4. sublime text格式化插件
  5. Fastjson介绍
  6. 安卓学习之ListView和GridView
  7. js四舍五入的bug和方法
  8. Understanding the Android Life Cycle
  9. URAL 1525 Path
  10. [笔记]我的Linux入门之路 - 01.Ubuntu安装
  11. MySQL InnoDB四个事务级别 与 脏读、不反复读、幻读
  12. EmguCV中图像类型进行转换
  13. 苹果新的编程语言 Swift 语言进阶(九)--方法和下标
  14. 采购,接收数据收集SQL汇总(从订单-&gt;接收-&gt;INVOICE所有数据关联SQL)
  15. JavaWeb处理GET、POST时的编码乱码问题
  16. 【SPFA与Dijkstra的对比】CDOJ 1961 咸鱼睡觉觉【差分约束-负权最短路径SPFA】
  17. Flutter常用组件(Widget)解析-Image
  18. 造轮子 | 怎样设计一个面向协议的 iOS 网络请求库
  19. 使用jmeter进行websocket协议压测
  20. hdu-2159(完全背包)

热门文章

  1. Java实现 LeetCode 57 插入区间
  2. 如何在交互式环境中执行Python程序
  3. nginx功能介绍和基本安装
  4. 6、react中的交互
  5. 手把手教你安装Ubuntu系统增强工具
  6. 如何在微信小程序中使用阿里字体图标
  7. ecshop php商城系统数据库结构及表的介绍分析
  8. CISCN 2019-ikun
  9. c常用函数-strchr和strrchr
  10. 恕我直言你可能真的不会java第3篇:Stream的Filter与谓词逻辑