力扣 - 剑指 Offer 53 - I. 在排序数组中查找数字 I
题目
思路1
- 一般来说,首先想到的是使用一个变量,从头开始遍历整个数组,记录
target数组出现的次数,但是这样的时间复杂度是O(n),还是不够高效 - 题目说了,是排序数组,一想到排序数组,我们可以想到使用二分法:
- 找出第一个
target所在的位置和最后一个target所在的位置,那么出现的次数就是end - start + 1了
- 找出第一个
代码
class Solution {
public int search(int[] nums, int target) {
// 获取第一个和最后一个target所在数组的位置
int start = getFirst(nums, 0, nums.length-1, target);
int end = getLast(nums, 0, nums.length-1, target);
// 只要start和end位置在在数组里面,就说明存在,否则返回0
if (start >= 0 && end >= 0) {
return end - start + 1;
}
return 0;
}
// 找到target所在数组第一次出现位置的下标
public int getFirst(int[] nums, int start, int end, int target) {
if (start > end) {
return -1;
}
int midIndex = start + (end - start) / 2;
int midValue = nums[midIndex];
if (target == midValue) {
// 递归的结束条件
// 当前就是第一个的情况:不是最左边的元素并且和前一个元素不相等、是最左边的元素
if ((midIndex != 0 && target != nums[midIndex - 1]) || midIndex == 0) {
return midIndex;
} else {
end = midIndex - 1;
}
} else if (target > midValue) {
start = midIndex + 1;
} else {
end = midIndex - 1;
}
// 根据新的start和end进行查找,找到后一路返回
return getFirst(nums, start, end, target);
}
// 找到target所在数组最后一次出现位置的下标
public int getLast(int[] nums, int start, int end, int target) {
if (start > end) {
return -1;
}
int midIndex = start + (end - start) / 2;
int midValue = nums[midIndex];
if (target == midValue) {
if ((midIndex != nums.length-1 && target != nums[midIndex+1]) || midIndex == nums.length-1) {
// 找到就返回
return midIndex;
} else {
// 右边还有与target相等的数,那么将start指向 midIndex+1,二分查找右边
start = midIndex + 1;
}
} else if (target > midValue) {
// 如果target大于midValue也是二分查找右边
start = midIndex + 1;
} else {
// 如果小于的话,就二分查找左边
end = midIndex - 1;
}
return getLast(nums, start, end, target);
}
}
复杂度分析
- 时间复杂度:\(O(logN)\)
- 空间复杂度:\(O(1)\)
力扣 - 剑指 Offer 53 - I. 在排序数组中查找数字 I的更多相关文章
- [简单-剑指 Offer 53 - I. 在排序数组中查找数字 I]
[简单-剑指 Offer 53 - I. 在排序数组中查找数字 I] 统计一个数字在排序数组中出现的次数. 示例 1: 输入: nums = [5,7,7,8,8,10], target = 8 输出 ...
- 剑指 Offer 53 - I. 在排序数组中查找数字 I + 二分法
剑指 Offer 53 - I. 在排序数组中查找数字 I Offer_53_1 题目描述 方法一:使用HashMap package com.walegarrett.offer; /** * @Au ...
- 剑指 Offer 53 - I. 在排序数组中查找数字 I
题目描述 统计一个数字在排序数组中出现的次数. 示例1: 输入: nums = [5,7,7,8,8,10], target = 8 输出: 2 示例2: 输入: nums = [5,7,7,8,8, ...
- 每日一题 - 剑指 Offer 53 - I. 在排序数组中查找数字 I
题目信息 时间: 2019-07-04 题目链接:Leetcode tag:二分查找 哈希表 难易程度:简单 题目描述: 统计一个数字在排序数组中出现的次数. 示例1: 输入: nums = [5,7 ...
- 力扣 - 剑指 Offer 53 - II. 0~n-1中缺失的数字
题目 剑指 Offer 53 - II. 0-n-1中缺失的数字 思路1 排序数组找数字使用二分法 通过题目,我们可以得到一个规律: 如果数组的索引值和该位置的值相等,说明还未缺失数字 一旦不相等了, ...
- [LeetCode]面试题53 - I. 在排序数组中查找数字 I(二分);面试题53 - II. 0~n-1中缺失的数字(二分)
##面试题53 - I. 在排序数组中查找数字 I ###题目 统计一个数字在排序数组中出现的次数. 示例 1: 输入: nums = [5,7,7,8,8,10], target = 8 输出: 2 ...
- 力扣 - 剑指 Offer 57. 和为s的两个数字
题目 剑指 Offer 57. 和为s的两个数字 思路1(哈希表) 这题首先想到的是使用两个for遍历,查找是哪两个相加等于target,但是时间复杂度确实\(O(N^2)\),时间复杂度太高,因此我 ...
- 《剑指offer》面试题53 - I. 在排序数组中查找数字 I
问题描述 统计一个数字在排序数组中出现的次数. 示例 1: 输入: nums = [5,7,7,8,8,10], target = 8 输出: 2 示例 2: 输入: nums = [5,7,7,8, ...
- 剑指 offer set 1 二维数组中查找
总结 1. 二维数组搜索题遇到两个了, 一个是 Leetcode 上 search in 2D matrix. 那道题比较简单, 因为下一行的所有元素大于上一行的. 这道题对二维矩阵的要求比较松, 起 ...
随机推荐
- Mybatis源码解析4——SqlSession
上一篇文章中,我们介绍了 SqlSessionFactory 的创建过程,忘记了的,可以回顾一下,或者看下下面这张图也行. 接下来,可乐讲给大家介绍 Mybatis 中另一个重量级嘉宾--SqlSes ...
- WEB安全性测试之拒绝服务攻击
1,认证 需要登录帐号的角色 2,授权 帐号的角色的操作范围 3,避免未经授权页面直接可以访问 使用绝对url(PS:绝对ur可以通过httpwatch监控每一个请求,获取请求对应的页面),登录后台的 ...
- 快速模式第三包收尾之quick_inI2()
快速模式第三包收尾之quick_inI2() 文章目录 快速模式第三包收尾之quick_inI2() 1. 序言 2. quick_inI2()处理流程图 3. 报文格式 4. quick_inI2( ...
- npm 淘宝镜像与官方源 切换
1.临时使用 npm --registry https://registry.npm.taobao.org install 包名 2.永久设置为淘宝镜像 npm config set registry ...
- liunx常见指令
linux目录结构 bin:存储普通命令 sbin:存储超级命令 home:存储普通用户 root:存储超级用户 usr /usr/local:下存储数据或软件,通常软件都放在其中 tmp:临时目录 ...
- UVA 506 System Dependencies(模拟 烂题)
https://vjudge.net/problem/UVA-506 题目是给出了五种指令,DEPEND.INSTALL.REMOVE.LIST.END,操作的格式及功能如下: DEPEND item ...
- 傻子都能懂的并查集题解——HDU1232畅通工程
原题内容: Problem Description 某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府"畅通工程"的目标是使全省任何两个城镇间都 ...
- linux centos系统 php安装GD库扩展
yum --enablerepo=remi-php56 install php-gd php-mysql php-mbstring php-xml php-mcrypt //安装GD库扩展 servi ...
- Dapr + .NET Core实战(五)Actor
什么是Actor模式 Actors 为最低级别的"计算单元" 以上解释来自官方文档,看起来"晦涩难懂".大白话就是说Actors模式是一段需要单线程执行的代码块 ...
- python编码问题:UnicodeDecodeError: 'gbk' codec can't decode byte 0xaf in position 68: illegal multibyte sequence
import yaml def test_yaml(): f = open('C:\hogwarts\Scripts\hogwarts-api\demo\yaml_data.yml') print(y ...