每日一题 - 剑指 Offer 53 - I. 在排序数组中查找数字 I
2021-04-27 17:26
标签:包含 思路 log 判断 turn 二分查找 难点 ++ 解决 时间: 2019-07-04 题目链接:Leetcode tag:二分查找 哈希表 难易程度:简单 题目描述: 统计一个数字在排序数组中出现的次数。 示例1: 示例2: 注意 本题难点 排序数组中查找数字,性能最优。 具体思路 排序数组中的搜索问题,首先想到 二分法 解决。 排序数组 nums 中的所有数字 target 形成一个窗口,记窗口的 左 / 右边界 索引分别为 left 和 right ,分别对应窗口左边 / 右边的首个元素。 统计数字 target 的出现次数,可转化为:使用二分法分别找到 左边界 left 和 右边界 right ,易得数字 target 的数量为 right?left?1 。 提示:查找完右边界后,可用 nums[j]=j 判断数组中是否包含 target ,若不包含则直接提前返回 0 ,无需后续查找左边界。查找完右边界后,左边界 left一定在闭区间 [0,j] 中,因此直接从此区间开始二分查找即可。 复杂度分析: 解题思路 直接遍历排序数组,计数。 代码 每日一题 - 剑指 Offer 53 - I. 在排序数组中查找数字 I 标签:包含 思路 log 判断 turn 二分查找 难点 ++ 解决 原文地址:https://www.cnblogs.com/ID-Wangqiang/p/13245382.html题目信息
输入: nums = [5,7,7,8,8,10], target = 8
输出: 2
输入: nums = [5,7,7,8,8,10], target = 6
输出: 0
1. 0
解题思路
代码
class Solution {
public int search(int[] nums, int target) {
// 搜索右边界 right
int i = 0, j = nums.length - 1;
while(i = 0 && nums[j] != target) return 0;
// 搜索左边界 right
i = 0;
while(i
其他优秀解答
class Solution {
public int search(int[] nums, int target) {
int count = 0;
for(int num : nums){
if(num == target){
count++;
}
}
return count;
}
}
文章标题:每日一题 - 剑指 Offer 53 - I. 在排序数组中查找数字 I
文章链接:http://soscw.com/essay/80032.html