前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >剑指Offer LeetCode 面试题53 - I. 在排序数组中查找数字 I

剑指Offer LeetCode 面试题53 - I. 在排序数组中查找数字 I

作者头像
手撕代码八百里
发布2020-07-28 23:27:26
5550
发布2020-07-28 23:27:26
举报
文章被收录于专栏:猿计划猿计划

面试题53 - I. 在排序数组中查找数字 I

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

示例 1:

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

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

简单暴力解法

代码语言:javascript
复制
class Solution {
    public int search(int[] nums, int target) {
        int sum=0;
        for(int i=0;i<nums.length;i++){
            if(nums[i]==target){
                sum++;
            }
        }
        return sum;
    }
}

二分查找

因为数组是已经排序好的数组,所以可以先找出左右边界,找到数组中的左右边界,然后相减就可以拿到这个数字了.

代码语言:javascript
复制
/**
 * @Auther: truedei
 * @Date: 2020 /20-5-20 08:45
 * @Description:
 */
public class Test1 {

    static  public int search(int[] nums, int target) {


        int i=0;
        int j=nums.length-1;
        int left=0,right=0;

        //搜索左边界
        while (i<=j){
            int mid =  (i + j) /2;

            if(nums[mid] <= target)
                i = i + 1;
            else
                j = j - 1;
        }

        right = i;

        i = 0;
        j=nums.length-1;

        //搜索右边界
        while (i<=j){
            int mid =  (i + j) /2;

            if(nums[mid] < target)
                i = i + 1;
            else
                j = j - 1;
        }

        left=j;

        return right - left - 1;
    }

    public static void main(String[] args) {
        int nums[] = new int[]{5,7,7,8,8,10},target = 8;


        System.out.println(search(nums,target));
    }
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-05-25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 面试题53 - I. 在排序数组中查找数字 I
  • 简单暴力解法
  • 二分查找
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档