力扣 - 剑指 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. 那道题比较简单, 因为下一行的所有元素大于上一行的. 这道题对二维矩阵的要求比较松, 起 ...
随机推荐
- Docker容器管理——Docker容器常用命令
1.查看所有的容器 docker ps 2.查看运行的容器 docker ps -a 3.启动.停止.重启docker容器 docker start ... docker stop ... docke ...
- MySQL——MySQL安装
1.rpm yum安装:安装方便.速度快.无法定制 2.二进制安装:解压即可使用,不能定制功能 3.编译安装: 可定制.安装慢: MySQL5.5之前:./configure make make in ...
- WEB漏洞——XSS
跨站脚本( Cross-site Scripting,简称为XSS或跨站脚本或跨站脚本攻击)是一种针对网站应用程序的安全漏洞攻击技术,是代码注入的一种. XSS攻击可以分为三种:反射型.存储型和DOM ...
- Git 系列教程(10)- 仓库别名
Git 别名 前言 Git 并不会在你输入部分命令时自动推断出你想要的命令 如果不想每次都输入完整的 Git 命令,可以通过 git config 文件来轻松地为每一个命令设置一个别名 $ git c ...
- window创建l2tp
windows上创建一个L2TP的隧道连接 进入控制面板,打开"网络和共享中心",如下图,之后点击"设置新的连接或网络" 进入到"设置连接或网络&qu ...
- Linux-实战常用命令
目录 关机/重启/注销 系统信息和性能查看 磁盘和分区 ⽤户和⽤户组 ⽹络和进程管理 常⻅系统服务命令 ⽂件和⽬录操作 ⽂件查看和处理 打包和解压 RPM包管理命令 YUM包管理命令 DPKG包管理命 ...
- 安卓gradle时报错"ERROR: Plugin with id 'com.android.application' not found."
在build.gradle中更改gradle插件版本号 buildscript { repositories { google() jcenter() } dependencies { //版本号请根 ...
- php实现实例化类后自动进行错误以及异常处理(简易版)
<?php class App { public function __construct() { /* * ini_set 设置配置项 * display_errors 是否在页面显示错误信息 ...
- 腾讯云启动jenkins
首先配置后jdk环境 可参考:https://www.cnblogs.com/Uni-Hoang/p/12991686.html 下载jenkins的war包 在/usr/local/创建一个jenk ...
- centos虚拟机中挂新硬盘
配置一台centos7,主硬盘20G装系统:副硬盘20G作为数据盘(格式:XFS)挂载到根目录:/vdir/ ,XFS是高性能文件系统. 外层vm硬盘添加好后,执行下面 1.fdisk -l //查看 ...