1. 程式人生 > 其它 >vs2015 community 安裝 及 專案測試

vs2015 community 安裝 及 專案測試

劍指 Offer 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

提示:

0 <= nums.length <= 105
-109 <= nums[i] <= 109
nums 是一個非遞減陣列
-109 <= target <= 109

class Solution {
    public int search(int[] nums, int target) {

            if(nums.length==0)return 0;
            if(nums.length==1&&nums[0]==target)return 1;
            else if(nums.length==1&&nums[0]!=target) return 0;

            int l = 0,r =nums.length-1;

            while(l<r)
            {
                int mid = (l+r)>>1;
                if(nums[mid]>=target) // [l,mid-1][mid,r]
                r = mid;  //左邊界 mid在左 右邊界mid在右 相反r =mid
                else
                {
                    l = mid+1;
                }
            }
            int cnt = 0;
            for(int i  = l ;i<nums.length;i++)
            {
                if(nums[i]==target)cnt++;
                else break;
            }
            return cnt;

    }
}