[OJ] Search for a Range
LintCode 61. Search for a Range (Medium)
LeetCode 34. Search for a Range (Medium)
class Solution {
private:
    int findBound(vector<int> &A, int target, bool findLowerBound) {
        int L = 0, R = A.size() - 1;
        while (L <= R) {
            int M = L + (R - L) / 2;
            if (A[M] < target) {
                L = M + 1;
            } else if (A[M] == target) {
                if (findLowerBound) {
                    R = M - 1;
                } else {
                    L = M + 1;
                }
            } else {
                R = M - 1;
            }
        }
        int res = findLowerBound ? L : R;
        return res >= 0 && res < A.size() && A[res] == target ? res : -1;
    }
public:
    vector<int> searchRange(vector<int> &A, int target) {
        vector<int> v;
        v.push_back(findBound(A, target, true));
        v.push_back(findBound(A, target, false));
        return v;
    }
};
时间复杂度: O(logn)
空间复杂度: O(1)
[OJ] Search for a Range的更多相关文章
- [Leetcode][Python]34: Search for a Range
		# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 34: Search for a Rangehttps://oj.leetco ... 
- Add Digits, Maximum Depth of BinaryTree, Search for a Range, Single Number,Find the Difference
		最近做的题记录下. 258. Add Digits Given a non-negative integer num, repeatedly add all its digits until the ... 
- LeetCode:Search Insert Position,Search for a Range (二分查找,lower_bound,upper_bound)
		Search Insert Position Given a sorted array and a target value, return the index if the target is fo ... 
- [LeetCode] 034. Search for a Range (Medium) (C++/Java)
		索引:[LeetCode] Leetcode 题解索引 (C++/Java/Python/Sql) Github: https://github.com/illuz/leetcode 035. Sea ... 
- leetCode 34.Search for a Range (搜索范围) 解题思路和方法
		Search for a Range Given a sorted array of integers, find the starting and ending position of a give ... 
- Leetcode::Longest Common Prefix && Search for a Range
		一次总结两道题,两道题目都比较基础 Description:Write a function to find the longest common prefix string amongst an a ... 
- [array]  leetcode - 34. Search for a Range - Medium
		leetcode - 34. Search for a Range - Medium descrition Given an array of integers sorted in ascending ... 
- 【LeetCode】34. Search for a Range
		Search for a Range Given a sorted array of integers, find the starting and ending position of a give ... 
- LeetCode: Search for a Range 解题报告
		Search for a RangeGiven a sorted array of integers, find the starting and ending position of a given ... 
随机推荐
- jquery无法读取json文件问题
			jquery无法读取json文件,如:user.json文件无法读取.把user.json文件的后缀名修改为aspx,文件内容不变,则可以读取~ 原理不懂!~~ 
- dom+bom
			一.判断最大值和最小值,注:arr为数组 最大值:Math.max.apply(null, arr); 最小值:Math.min.apply(null, arr); 二.BOM 打开新页面和关闭打 ... 
- 关于GC进行垃圾回收的时机
			前言 今天查看一个同事的代码,发现代码中多处地方使用了GC.Collect()方法,我问他为什么这么做,他说感觉程序中定义了好多变量,怕GC回收不及时,用GC.Collect()可以手动掌控GC进行垃 ... 
- 基于注解整合struts2与spring的时候如果不引入struts2-spring-plugin包自动装配无效
			基于注解整合struts2与spring的时候如果不引入struts2-spring-plugin包,自动装配将无效,需要spring注入的对象使用时将抛出空指针异常(NullPointerExcep ... 
- Ambiguous handler methods mapped for HTTP path
			一.问题:映射重复导致的错误 java代码如下: @RequestMapping(value = "/info/{remove}/{id}", method = RequestMe ... 
- Cogs 1008. 贪婪大陆(树状数组)
			贪婪大陆 难度等级 ★★ 时间限制 1000 ms (1 s) 内存限制 128 MB 测试数据 10 简单对比 输入文件:greedisland.in 输出文件:greedisland.out 简单 ... 
- SGU 281.Championship
			题意: 有n(n≤50000)支队伍参加了两场比赛,分别有两个排名.现在要求输出总排名,如果对任意m,在两个排名的前m个队伍都相同,那么在总排名前m个队伍就是这些队伍.其它情况按字典序排. Solut ... 
- 相看系统中用户的信息 passwd, shadow
			用用户的信息都保存在 etc/passwd 和 etc/shadow 文件中,其中 shadow 保存的是经过加密码的 能过 cat etc/passwd 和 cat etc/shadow 来查看相关 ... 
- [C#]『Barrier』任务并行库使用小计
			Barrier 是一个对象,它可以在并行操作中的所有任务都达到相应的关卡之前,阻止各个任务继续执行. 如果并行操作是分阶段执行的,并且每一阶段要求各任务之间进行同步,则可以使用该对象. --MSDN ... 
- 【转】Oracle job procedure 存储过程定时任务
			原文:Oracle job procedure 存储过程定时任务 oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的job,可以查询视图 --相 ... 
