[STL] lower_bound和upper_bound实现

    int lower_bound(vector& nums, int target) {
        int lo = 0, hi = nums.size() - 1;
        
        while (lo <= hi) {	// equal
            int mid = lo + (hi - lo) / 2;
            if (target > nums[mid]) {
                lo = mid + 1;
            } else {
                hi = mid - 1;	// mid - 1 !!
            }
        }
        
        return lo;
    }
    int upper_bound(vector& nums, int target) {
        int lo = 0, hi = nums.size() - 1;
        
        while (lo <= hi) {	// equal !!
            int mid = lo + (hi - lo) / 2;
            if (target >= nums[mid]) {
                lo = mid + 1;
            } else {
                hi = mid - 1;		// mid - 1 !!
            }
        }
        
        return lo;
    }

你可能感兴趣的:(c++)